44require_once DOL_DOCUMENT_ROOT.
'/core/class/commonobject.class.php';
45require_once DOL_DOCUMENT_ROOT.
'/core/class/commonincoterm.class.php';
46require_once DOL_DOCUMENT_ROOT.
'/core/class/commonsocialnetworks.class.php';
47require_once DOL_DOCUMENT_ROOT.
'/core/class/commonpeople.class.php';
48require_once DOL_DOCUMENT_ROOT.
'/multicurrency/class/multicurrency.class.php';
63 public $module =
'societe';
68 public $element =
'societe';
73 public $table_element =
'societe';
78 public $fk_element =
'fk_soc';
83 public $fieldsforcombobox =
'nom,name_alias';
88 protected $childtables = array(
89 'supplier_proposal' => array(
'name' =>
'SupplierProposal'),
90 'propal' => array(
'name' =>
'Proposal'),
91 'commande' => array(
'name' =>
'Order'),
92 'facture' => array(
'name' =>
'Invoice'),
93 'facture_rec' => array(
'name' =>
'RecurringInvoiceTemplate'),
94 'contrat' => array(
'name' =>
'Contract'),
95 'fichinter' => array(
'name' =>
'Fichinter'),
96 'facture_fourn' => array(
'name' =>
'SupplierInvoice'),
97 'commande_fournisseur' => array(
'name' =>
'SupplierOrder'),
98 'projet' => array(
'name' =>
'Project'),
99 'expedition' => array(
'name' =>
'Shipment'),
100 'prelevement_lignes' => array(
'name' =>
'DirectDebitRecord'),
107 protected $childtablesoncascade = array(
109 'product_fournisseur_price',
110 'product_customer_price_log',
111 'product_customer_price',
112 '@Contact:/contact/class/contact.class.php:fk_soc',
117 'societe_remise_except',
118 'societe_commerciaux',
128 public $picto =
'company';
134 public $restrictiononfksoc = 1;
140 public $SupplierCategories = array();
146 public $prefixCustomerIsRequired;
177 public $fields = array(
178 'rowid' => array(
'type' =>
'integer',
'label' =>
'TechnicalID',
'enabled' => 1,
'visible' => -2,
'noteditable' => 1,
'notnull' => 1,
'index' => 1,
'position' => 1,
'comment' =>
'Id',
'css' =>
'left'),
179 'parent' => array(
'type' =>
'integer',
'label' =>
'Parent',
'enabled' => 1,
'visible' => -1,
'position' => 20),
180 'tms' => array(
'type' =>
'timestamp',
'label' =>
'DateModification',
'enabled' => 1,
'visible' => -1,
'notnull' => 1,
'position' => 25),
181 'datec' => array(
'type' =>
'datetime',
'label' =>
'DateCreation',
'enabled' => 1,
'visible' => -1,
'position' => 30),
182 'nom' => array(
'type' =>
'varchar(128)',
'length' => 128,
'label' =>
'Nom',
'enabled' => 1,
'visible' => -1,
'position' => 35,
'showoncombobox' => 1,
'csslist' =>
'tdoverflowmax150'),
183 'name_alias' => array(
'type' =>
'varchar(128)',
'label' =>
'Name alias',
'enabled' => 1,
'visible' => -1,
'position' => 36,
'showoncombobox' => 2),
184 'entity' => array(
'type' =>
'integer',
'label' =>
'Entity',
'default' =>
'1',
'enabled' => 1,
'visible' => -2,
'notnull' => 1,
'position' => 40,
'index' => 1),
185 'ref_ext' => array(
'type' =>
'varchar(255)',
'label' =>
'RefExt',
'enabled' => 1,
'visible' => 0,
'position' => 45),
186 'code_client' => array(
'type' =>
'varchar(24)',
'label' =>
'CustomerCode',
'enabled' => 1,
'visible' => -1,
'position' => 55),
187 'code_fournisseur' => array(
'type' =>
'varchar(24)',
'label' =>
'SupplierCode',
'enabled' => 1,
'visible' => -1,
'position' => 60),
188 'code_compta' => array(
'type' =>
'varchar(24)',
'label' =>
'CustomerAccountancyCode',
'enabled' => 1,
'visible' => -1,
'position' => 65),
189 'code_compta_fournisseur' => array(
'type' =>
'varchar(24)',
'label' =>
'SupplierAccountancyCode',
'enabled' => 1,
'visible' => -1,
'position' => 70),
190 'address' => array(
'type' =>
'varchar(255)',
'label' =>
'Address',
'enabled' => 1,
'visible' => -1,
'position' => 75),
191 'zip' => array(
'type' =>
'varchar(25)',
'label' =>
'Zip',
'enabled' => 1,
'visible' => -1,
'position' => 80),
192 'town' => array(
'type' =>
'varchar(50)',
'label' =>
'Town',
'enabled' => 1,
'visible' => -1,
'position' => 85),
193 'fk_departement' => array(
'type' =>
'integer',
'label' =>
'State',
'enabled' => 1,
'visible' => -1,
'position' => 90),
194 'fk_pays' => array(
'type' =>
'integer:Ccountry:core/class/ccountry.class.php',
'label' =>
'Country',
'enabled' => 1,
'visible' => -1,
'position' => 95),
195 'phone' => array(
'type' =>
'varchar(20)',
'label' =>
'Phone',
'enabled' => 1,
'visible' => -1,
'position' => 100),
196 'phone_mobile' => array(
'type' =>
'varchar(20)',
'label' =>
'PhoneMobile',
'enabled' => 1,
'visible' => -1,
'position' => 102),
197 'fax' => array(
'type' =>
'varchar(20)',
'label' =>
'Fax',
'enabled' => 1,
'visible' => -1,
'position' => 105),
198 'url' => array(
'type' =>
'varchar(255)',
'label' =>
'Url',
'enabled' => 1,
'visible' => -1,
'position' => 110),
199 'email' => array(
'type' =>
'varchar(128)',
'label' =>
'Email',
'enabled' => 1,
'visible' => -1,
'position' => 115),
200 'socialnetworks' => array(
'type' =>
'text',
'label' =>
'Socialnetworks',
'enabled' => 1,
'visible' => -1,
'position' => 120),
201 'fk_effectif' => array(
'type' =>
'integer',
'label' =>
'Workforce',
'enabled' => 1,
'visible' => -1,
'position' => 170),
202 'fk_typent' => array(
'type' =>
'integer',
'label' =>
'TypeOfCompany',
'enabled' => 1,
'visible' => -1,
'position' => 175,
'csslist' =>
'minwidth200'),
203 'fk_forme_juridique' => array(
'type' =>
'integer',
'label' =>
'JuridicalStatus',
'enabled' => 1,
'visible' => -1,
'position' => 180),
204 'fk_currency' => array(
'type' =>
'varchar(3)',
'label' =>
'Currency',
'enabled' => 1,
'visible' => -1,
'position' => 185),
205 'siren' => array(
'type' =>
'varchar(128)',
'label' =>
'Idprof1',
'enabled' => 1,
'visible' => -1,
'position' => 190),
206 'siret' => array(
'type' =>
'varchar(128)',
'label' =>
'Idprof2',
'enabled' => 1,
'visible' => -1,
'position' => 195),
207 'ape' => array(
'type' =>
'varchar(128)',
'label' =>
'Idprof3',
'enabled' => 1,
'visible' => -1,
'position' => 200),
208 'idprof4' => array(
'type' =>
'varchar(128)',
'label' =>
'Idprof4',
'enabled' => 1,
'visible' => -1,
'position' => 205),
209 'idprof5' => array(
'type' =>
'varchar(128)',
'label' =>
'Idprof5',
'enabled' => 1,
'visible' => -1,
'position' => 206),
210 'idprof6' => array(
'type' =>
'varchar(128)',
'label' =>
'Idprof6',
'enabled' => 1,
'visible' => -1,
'position' => 207),
211 'tva_intra' => array(
'type' =>
'varchar(20)',
'label' =>
'Tva intra',
'enabled' => 1,
'visible' => -1,
'position' => 210),
212 'capital' => array(
'type' =>
'double(24,8)',
'label' =>
'Capital',
'enabled' => 1,
'visible' => -1,
'position' => 215),
213 'fk_stcomm' => array(
'type' =>
'integer',
'label' =>
'CommercialStatus',
'enabled' => 1,
'visible' => -1,
'notnull' => 1,
'position' => 220),
214 'note_public' => array(
'type' =>
'html',
'label' =>
'NotePublic',
'enabled' => 1,
'visible' => 0,
'position' => 225),
215 'note_private' => array(
'type' =>
'html',
'label' =>
'NotePrivate',
'enabled' => 1,
'visible' => 0,
'position' => 230),
216 'prefix_comm' => array(
'type' =>
'varchar(5)',
'label' =>
'Prefix comm',
'enabled' =>
"getDolGlobalInt('SOCIETE_USEPREFIX')",
'visible' => -1,
'position' => 235),
217 'client' => array(
'type' =>
'tinyint(4)',
'label' =>
'Client',
'enabled' => 1,
'visible' => -1,
'position' => 240),
218 'fournisseur' => array(
'type' =>
'tinyint(4)',
'label' =>
'Fournisseur',
'enabled' => 1,
'visible' => -1,
'position' => 245),
219 'supplier_account' => array(
'type' =>
'varchar(32)',
'label' =>
'Supplier account',
'enabled' => 1,
'visible' => -1,
'position' => 250),
220 'fk_prospectlevel' => array(
'type' =>
'varchar(12)',
'label' =>
'ProspectLevel',
'enabled' => 1,
'visible' => -1,
'position' => 255),
221 'customer_bad' => array(
'type' =>
'tinyint(4)',
'label' =>
'Customer bad',
'enabled' => 1,
'visible' => -1,
'position' => 260),
222 'customer_rate' => array(
'type' =>
'double',
'label' =>
'Customer rate',
'enabled' => 1,
'visible' => -1,
'position' => 265),
223 'supplier_rate' => array(
'type' =>
'double',
'label' =>
'Supplier rate',
'enabled' => 1,
'visible' => -1,
'position' => 270),
224 'fk_user_creat' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserAuthor',
'enabled' => 1,
'visible' => -2,
'position' => 275),
225 'fk_user_modif' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserModif',
'enabled' => 1,
'visible' => -2,
'notnull' => -1,
'position' => 280),
228 'mode_reglement' => array(
'type' =>
'tinyint(4)',
'label' =>
'Mode reglement',
'enabled' => 1,
'visible' => -1,
'position' => 295),
229 'cond_reglement' => array(
'type' =>
'tinyint(4)',
'label' =>
'Cond reglement',
'enabled' => 1,
'visible' => -1,
'position' => 300),
230 'deposit_percent' => array(
'type' =>
'varchar(63)',
'label' =>
'DepositPercent',
'enabled' => 1,
'visible' => -1,
'position' => 301),
231 'mode_reglement_supplier' => array(
'type' =>
'integer',
'label' =>
'Mode reglement supplier',
'enabled' => 1,
'visible' => -1,
'position' => 305),
232 'cond_reglement_supplier' => array(
'type' =>
'integer',
'label' =>
'Cond reglement supplier',
'enabled' => 1,
'visible' => -1,
'position' => 308),
233 'outstanding_limit' => array(
'type' =>
'double(24,8)',
'label' =>
'OutstandingBill',
'enabled' => 1,
'visible' => -1,
'position' => 310,
'isameasure' => 1),
234 'order_min_amount' => array(
'type' =>
'double(24,8)',
'label' =>
'Order min amount',
'enabled' =>
'isModEnabled("order") && !empty($conf->global->ORDER_MANAGE_MIN_AMOUNT)',
'visible' => -1,
'position' => 315,
'isameasure' => 1),
235 'supplier_order_min_amount' => array(
'type' =>
'double(24,8)',
'label' =>
'Supplier order min amount',
'enabled' =>
'isModEnabled("order") && !empty($conf->global->ORDER_MANAGE_MIN_AMOUNT)',
'visible' => -1,
'position' => 320,
'isameasure' => 1),
236 'fk_shipping_method' => array(
'type' =>
'integer',
'label' =>
'Fk shipping method',
'enabled' => 1,
'visible' => -1,
'position' => 330),
237 'tva_assuj' => array(
'type' =>
'tinyint(4)',
'label' =>
'Tva assuj',
'enabled' => 1,
'visible' => -1,
'position' => 335),
238 'localtax1_assuj' => array(
'type' =>
'tinyint(4)',
'label' =>
'Localtax1 assuj',
'enabled' => 1,
'visible' => -1,
'position' => 340),
239 'localtax1_value' => array(
'type' =>
'double(6,3)',
'label' =>
'Localtax1 value',
'enabled' => 1,
'visible' => -1,
'position' => 345),
240 'localtax2_assuj' => array(
'type' =>
'tinyint(4)',
'label' =>
'Localtax2 assuj',
'enabled' => 1,
'visible' => -1,
'position' => 350),
241 'localtax2_value' => array(
'type' =>
'double(6,3)',
'label' =>
'Localtax2 value',
'enabled' => 1,
'visible' => -1,
'position' => 355),
242 'vat_reverse_charge' => array(
'type' =>
'tinyint(4)',
'label' =>
'Vat reverse charge',
'enabled' => 1,
'visible' => -1,
'position' => 335),
243 'barcode' => array(
'type' =>
'varchar(255)',
'label' =>
'Barcode',
'enabled' => 1,
'visible' => -1,
'position' => 360),
244 'price_level' => array(
'type' =>
'integer',
'label' =>
'Price level',
'enabled' =>
'$conf->global->PRODUIT_MULTIPRICES || getDolGlobalString("PRODUIT_CUSTOMER_PRICES_BY_QTY_MULTIPRICES") || getDolGlobalString("PRODUIT_CUSTOMER_PRICES_AND_MULTIPRICES")',
'visible' => -1,
'position' => 365),
245 'default_lang' => array(
'type' =>
'varchar(6)',
'label' =>
'Default lang',
'enabled' => 1,
'visible' => -1,
'position' => 370),
246 'canvas' => array(
'type' =>
'varchar(32)',
'label' =>
'Canvas',
'enabled' => 1,
'visible' => -1,
'position' => 375),
247 'fk_barcode_type' => array(
'type' =>
'integer',
'label' =>
'Fk barcode type',
'enabled' => 1,
'visible' => -1,
'position' => 405),
248 'webservices_url' => array(
'type' =>
'varchar(255)',
'label' =>
'Webservices url',
'enabled' => 1,
'visible' => -1,
'position' => 410),
249 'webservices_key' => array(
'type' =>
'varchar(128)',
'label' =>
'Webservices key',
'enabled' => 1,
'visible' => -1,
'position' => 415),
250 'fk_incoterms' => array(
'type' =>
'integer',
'label' =>
'Fk incoterms',
'enabled' => 1,
'visible' => -1,
'position' => 425),
251 'location_incoterms' => array(
'type' =>
'varchar(255)',
'label' =>
'Location incoterms',
'enabled' => 1,
'visible' => -1,
'position' => 430),
252 'model_pdf' => array(
'type' =>
'varchar(255)',
'label' =>
'Model pdf',
'enabled' => 1,
'visible' => 0,
'position' => 435),
253 'last_main_doc' => array(
'type' =>
'varchar(255)',
'label' =>
'LastMainDoc',
'enabled' => 1,
'visible' => -1,
'position' => 270),
254 'fk_multicurrency' => array(
'type' =>
'integer',
'label' =>
'Fk multicurrency',
'enabled' => 1,
'visible' => -1,
'position' => 440),
255 'multicurrency_code' => array(
'type' =>
'varchar(255)',
'label' =>
'Multicurrency code',
'enabled' => 1,
'visible' => -1,
'position' => 445),
256 'fk_account' => array(
'type' =>
'integer',
'label' =>
'PaymentBankAccount',
'enabled' => 1,
'visible' => -1,
'position' => 450),
257 'fk_warehouse' => array(
'type' =>
'integer',
'label' =>
'Warehouse',
'enabled' => 1,
'visible' => -1,
'position' => 455),
258 'logo' => array(
'type' =>
'varchar(255)',
'label' =>
'Logo',
'enabled' => 1,
'visible' => -1,
'position' => 400),
259 'logo_squarred' => array(
'type' =>
'varchar(255)',
'label' =>
'Logo squarred',
'enabled' => 1,
'visible' => -1,
'position' => 401),
260 'status' => array(
'type' =>
'tinyint(4)',
'label' =>
'Status',
'enabled' => 1,
'visible' => -1,
'position' => 500),
261 'import_key' => array(
'type' =>
'varchar(14)',
'label' =>
'ImportId',
'enabled' => 1,
'visible' => -2,
'position' => 1000),
319 public $departement_code;
344 public $phone_mobile;
491 public $socialobject;
501 public $tva_assuj = 1;
511 public $vat_reverse_charge = 0;
517 public $localtax1_assuj;
521 public $localtax1_value;
525 public $localtax2_assuj;
529 public $localtax2_value;
544 public $typent_id = 0;
556 public $effectif_id = 0;
560 public $forme_juridique_code = 0;
565 public $forme_juridique;
570 public $remise_percent;
574 public $remise_supplier_percent;
579 public $mode_reglement_id;
583 public $cond_reglement_id;
587 public $deposit_percent;
591 public $mode_reglement_supplier_id;
595 public $cond_reglement_supplier_id;
599 public $transport_mode_supplier_id;
604 public $fk_prospectlevel;
616 public $user_modification;
623 public $user_creation;
635 public $prospect = 0;
653 public $code_fournisseur;
659 public $code_compta_client;
665 public $accountancy_code_customer_general;
671 public $accountancy_code_customer;
677 public $code_compta_fournisseur;
683 public $accountancy_code_supplier_general;
689 public $accountancy_code_supplier;
695 public $code_compta_product;
708 public $note_private;
726 public $stcomm_picto;
732 public $status_prospect_label;
743 public $outstanding_limit;
748 public $order_min_amount;
753 public $supplier_order_min_amount;
759 public $commercial_id;
771 public $default_lang;
802 public $webservices_url;
808 public $webservices_key;
828 public $logo_squarred;
833 public $logo_squarred_small;
838 public $logo_squarred_mini;
843 public $accountancy_code_sell;
848 public $accountancy_code_buy;
854 public $fk_multicurrency;
859 public $multicurrency_code;
865 public $fk_warehouse;
878 public $partnerships = array();
884 public $bank_account;
887 const STATUS_CEASED = 0;
888 const STATUS_INACTIVITY = 1;
929 'code_compta' =>
'code_compta_client',
931 + parent::deprecatedProperties();
945 $this->ismultientitymanaged = 1;
946 $this->isextrafieldmanaged = 1;
949 $this->fournisseur = 0;
950 $this->typent_id = 0;
951 $this->effectif_id = 0;
952 $this->forme_juridique_code = 0;
953 $this->tva_assuj = 1;
954 $this->vat_reverse_charge = 0;
958 $this->fields[
'address'][
'showoncombobox'] =
getDolGlobalInt(
'COMPANY_SHOW_ADDRESS_SELECTLIST');
959 $this->fields[
'zip'][
'showoncombobox'] =
getDolGlobalInt(
'COMPANY_SHOW_ADDRESS_SELECTLIST');
960 $this->fields[
'town'][
'showoncombobox'] =
getDolGlobalInt(
'COMPANY_SHOW_ADDRESS_SELECTLIST');
976 global $langs,
$conf;
981 if (empty($this->
status)) {
984 $this->
name = $this->
name ? trim($this->
name) : trim((
string) $this->nom);
986 $this->nom = $this->name;
988 if (empty($this->client)) {
991 if (empty($this->fournisseur)) {
992 $this->fournisseur = 0;
994 $this->import_key = trim((
string) $this->import_key);
996 $this->code_compta_client = trim($this->code_compta_client);
998 $this->accountancy_code_customer_general = trim($this->accountancy_code_customer_general);
999 $this->accountancy_code_customer = trim((
string) $this->code_compta_client);
1000 $this->accountancy_code_supplier_general = trim($this->accountancy_code_supplier_general);
1001 $this->accountancy_code_supplier = trim((
string) $this->code_compta_fournisseur);
1002 $this->accountancy_code_buy = trim((
string) $this->accountancy_code_buy);
1003 $this->accountancy_code_sell = trim((
string) $this->accountancy_code_sell);
1005 if (!empty($this->multicurrency_code)) {
1008 if (empty($this->fk_multicurrency)) {
1009 $this->multicurrency_code =
'';
1010 $this->fk_multicurrency = 0;
1013 if (empty($this->country_id) && !empty($this->country_code)) {
1014 $country_id =
getCountry($this->country_code,
'3');
1015 $this->country_id = is_int($country_id) ? $country_id : 0;
1022 if (empty($this->date_creation)) {
1023 $this->date_creation = $now;
1029 if ($this->code_client == -1 || $this->code_client ===
'auto') {
1030 $this->get_codeclient($this, 0);
1032 if ($this->code_fournisseur ==
'-1' || $this->code_fournisseur ===
'auto') {
1033 $this->get_codefournisseur($this, 1);
1038 $result = $this->
verify();
1043 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"societe (";
1045 $sql .=
", name_alias";
1048 $sql .=
", fk_user_creat";
1049 $sql .=
", fk_typent";
1052 $sql .=
", ref_ext";
1053 $sql .=
", fk_stcomm";
1054 $sql .=
", fk_incoterms";
1055 $sql .=
", location_incoterms";
1056 $sql .=
", import_key";
1057 $sql .=
", fk_multicurrency";
1058 $sql .=
", multicurrency_code";
1061 $sql .=
", vat_reverse_charge";
1062 $sql .=
", accountancy_code_buy";
1063 $sql .=
", accountancy_code_sell";
1065 $sql .=
") VALUES ('".$this->db->escape($this->name).
"',";
1066 $sql .=
" '".$this->db->escape($this->name_alias).
"',";
1067 $sql .=
" ".((int) $this->entity).
",";
1068 $sql .=
" '".$this->db->idate($this->date_creation).
"'";
1069 $sql .=
", ".(!empty($user->id) ? ((int) $user->id) :
"null");
1070 $sql .=
", ".(!empty($this->typent_id) ? ((int) $this->typent_id) :
"null");
1071 $sql .=
", ".(!empty($this->canvas) ?
"'".$this->db->escape($this->canvas).
"'" :
"null");
1072 $sql .=
", ".((int) $this->
status);
1073 $sql .=
", ".(!empty($this->ref_ext) ?
"'".$this->db->escape($this->ref_ext).
"'" :
"null");
1075 $sql .=
", ".(int) $this->fk_incoterms;
1076 $sql .=
", '".$this->db->escape($this->location_incoterms).
"'";
1077 $sql .=
", ".(!empty($this->import_key) ?
"'".$this->db->escape($this->import_key).
"'" :
"null");
1078 $sql .=
", ".(int) $this->fk_multicurrency;
1079 $sql .=
", '".$this->db->escape($this->multicurrency_code).
"'";
1080 $sql .=
", '".$this->db->escape($this->ip).
"'";
1082 $sql .=
", ".(empty($this->vat_reverse_charge) ?
'0' :
'1');
1083 $sql .=
", '" . $this->db->escape($this->accountancy_code_buy) .
"'";
1084 $sql .=
", '" . $this->db->escape($this->accountancy_code_sell) .
"'";
1088 dol_syslog(get_class($this).
"::create", LOG_DEBUG);
1090 $result = $this->db->query($sql);
1092 $this->
id = $this->db->last_insert_id(MAIN_DB_PREFIX.
"societe");
1094 $ret = $this->
update($this->
id, $user, 0, 1, 1,
'add');
1098 $this->db->query(
"DELETE FROM ".MAIN_DB_PREFIX.
"societe_perentity WHERE fk_soc = ".((
int) $this->id).
" AND entity = ".((
int)
$conf->entity));
1100 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"societe_perentity (";
1103 $sql .=
", vat_reverse_charge";
1104 $sql .=
", accountancy_code_customer_general";
1105 $sql .=
", accountancy_code_customer";
1106 $sql .=
", accountancy_code_supplier_general";
1107 $sql .=
", accountancy_code_supplier";
1108 $sql .=
", accountancy_code_buy";
1109 $sql .=
", accountancy_code_sell";
1110 $sql .=
") VALUES (";
1112 $sql .=
", ".((int)
$conf->entity);
1113 $sql .=
", ".(empty($this->vat_reverse_charge) ?
'0' :
'1');
1114 $sql .=
", '".$this->db->escape($this->accountancy_code_customer_general).
"'";
1115 $sql .=
", '".$this->db->escape($this->accountancy_code_customer).
"'";
1116 $sql .=
", '".$this->db->escape($this->accountancy_code_supplier_general).
"'";
1117 $sql .=
", '".$this->db->escape($this->accountancy_code_supplier).
"'";
1118 $sql .=
", '".$this->db->escape($this->accountancy_code_buy).
"'";
1119 $sql .=
", '".$this->db->escape($this->accountancy_code_sell).
"'";
1121 $result = $this->db->query($sql);
1124 $this->error =
'ErrorFailedToUpdateAccountancyForEntity';
1129 if ($this->commercial_id !=
'' && $this->commercial_id != -1) {
1131 } elseif (!$user->hasRight(
'societe',
'client',
'voir')) {
1139 $result = $this->
call_trigger(
'COMPANY_CREATE', $user);
1150 dol_syslog(get_class($this).
"::Create success id=".$this->
id);
1151 $this->db->commit();
1154 dol_syslog(get_class($this).
"::Create echec update ".$this->error.(empty($this->errors) ?
'' :
' '.implode(
',', $this->errors)), LOG_ERR);
1155 $this->db->rollback();
1159 if ($this->db->lasterrno() ==
'DB_ERROR_RECORD_ALREADY_EXISTS') {
1160 $this->error = $langs->trans(
"ErrorCompanyNameAlreadyExists", $this->name);
1163 $this->error = $this->db->lasterror();
1166 $this->db->rollback();
1170 $this->db->rollback();
1171 dol_syslog(get_class($this).
"::Create fails verify ".implode(
',', $this->errors), LOG_WARNING);
1196 require_once DOL_DOCUMENT_ROOT.
'/contact/class/contact.class.php';
1197 $contact =
new Contact($this->db);
1199 $contact->name = $this->name_bis;
1200 $contact->firstname = $this->firstname;
1201 $contact->civility_id = $this->civility_id;
1202 $contact->socid = $this->id;
1203 $contact->statut = 1;
1204 $contact->status = 1;
1206 $contact->country_id = $this->country_id;
1207 $contact->state_id = $this->state_id;
1208 $contact->address = $this->address;
1209 $contact->email = $this->email;
1210 $contact->zip = $this->zip;
1211 $contact->town = $this->town;
1213 $contact->phone_pro = $this->phone;
1218 $contactId = $contact->create($user, $notrigger);
1219 if ($contactId < 0) {
1222 dol_syslog(get_class($this).
"::create_individual ERROR:".$this->error, LOG_ERR);
1225 if (empty($error) && is_array($tags) && !empty($tags)) {
1226 $result = $contact->setCategories($tags);
1230 dol_syslog(get_class($this).
"::create_individual Affect Tag ERROR:".$this->error, LOG_ERR);
1231 $contactId = $result;
1235 if (empty($error) && isModEnabled(
'mailing') && !empty($contact->email) && isset($no_email)) {
1236 $result = $contact->setNoEmail($no_email);
1239 dol_syslog(get_class($this).
"::create_individual set mailing status ERROR:".$this->error, LOG_ERR);
1240 $contactId = $result;
1244 if (empty($error)) {
1245 dol_syslog(get_class($this).
"::create_individual success");
1246 $this->db->commit();
1248 $this->db->rollback();
1262 global
$conf, $langs, $mysoc;
1265 $this->errors = array();
1269 $this->nom = $this->name;
1272 $this->errors[] =
'ErrorBadThirdPartyName';
1276 if ($this->client) {
1278 if ($rescode != 0 && $rescode != -5) {
1279 if ($rescode == -1) {
1280 $this->errors[] =
'ErrorBadCustomerCodeSyntax';
1281 } elseif ($rescode == -2) {
1282 $this->errors[] =
'ErrorCustomerCodeRequired';
1283 } elseif ($rescode == -3) {
1284 $this->errors[] =
'ErrorCustomerCodeAlreadyUsed';
1285 } elseif ($rescode == -4) {
1286 $this->errors[] =
'ErrorPrefixRequired';
1288 $this->errors[] =
'ErrorUnknownOnCustomerCodeCheck';
1295 if ($this->fournisseur) {
1297 if ($rescode != 0 && $rescode != -5) {
1298 if ($rescode == -1) {
1299 $this->errors[] =
'ErrorBadSupplierCodeSyntax';
1300 } elseif ($rescode == -2) {
1301 $this->errors[] =
'ErrorSupplierCodeRequired';
1302 } elseif ($rescode == -3) {
1303 $this->errors[] =
'ErrorSupplierCodeAlreadyUsed';
1304 } elseif ($rescode == -4) {
1305 $this->errors[] =
'ErrorPrefixRequired';
1307 $this->errors[] =
'ErrorUnknownOnSupplierCodeCheck';
1314 $array_to_check = array(
'IDPROF1',
'IDPROF2',
'IDPROF3',
'IDPROF4',
'IDPROF5',
'IDPROF6',
'EMAIL',
'TVA_INTRA',
'ACCOUNTANCY_CODE_CUSTOMER',
'ACCOUNTANCY_CODE_SUPPLIER');
1315 foreach ($array_to_check as $key) {
1316 $keymin = strtolower($key);
1317 $keyfield_db = $keymin;
1318 if ($key ==
'ACCOUNTANCY_CODE_CUSTOMER') {
1319 $keymin =
'code_compta_client';
1320 $keyfield_db =
'code_compta';
1321 } elseif ($key ==
'ACCOUNTANCY_CODE_SUPPLIER') {
1322 $keymin =
'code_compta_fournisseur';
1323 $keyfield_db =
'code_compta_fournisseur';
1325 $i = (int) preg_replace(
'/[^0-9]/',
'', $key);
1326 $vallabel = $this->$keymin;
1331 if ($mysoc->country_id > 0 && $this->country_id == $mysoc->country_id) {
1332 $idprof_mandatory =
'SOCIETE_'.$key.
'_MANDATORY';
1334 $langs->load(
"errors");
1336 $this->errors[] = $langs->trans(
"ErrorProdIdIsMandatory", $langs->transcountry(
'ProfId'.$i, $this->country_code)).
' ('.$langs->trans(
"ForbiddenBySetupRules").
')';
1343 if ($this->
id_prof_exists($keymin, $vallabel, ($this->
id > 0 ? $this->
id : 0))) {
1344 $langs->load(
"errors");
1346 $this->errors[] = $langs->transcountry(
'ProfId'.$i, $this->country_code).
" ".$langs->trans(
"ErrorProdIdAlreadyExist", $vallabel).
' ('.$langs->trans(
"ForbiddenBySetupRules").
')';
1352 if ($key ==
'EMAIL') {
1355 $langs->load(
"errors");
1357 $this->errors[] = $langs->trans(
"ErrorBadEMail", $this->
email).
' ('.$langs->trans(
"ForbiddenBySetupRules").
')';
1362 if ($this->
id_prof_exists($keymin, $vallabel, ($this->
id > 0 ? $this->
id : 0))) {
1363 $langs->load(
"errors");
1365 $this->errors[] = $langs->trans(
'Email').
" ".$langs->trans(
"ErrorProdIdAlreadyExist", $vallabel).
' ('.$langs->trans(
"ForbiddenBySetupRules").
')';
1368 } elseif ($key ==
'TVA_INTRA') {
1371 if ($this->
id_prof_exists($keymin, $vallabel, ($this->
id > 0 ? $this->
id : 0))) {
1372 $langs->load(
"errors");
1374 $this->errors[] = $langs->trans(
'VATIntra').
" ".$langs->trans(
"ErrorProdIdAlreadyExist", $vallabel).
' ('.$langs->trans(
"ForbiddenBySetupRules").
')';
1377 if ($this->tva_assuj && !$vallabel &&
getDolGlobalString(
'SOCIETE_VAT_INTRA_MANDATORY')) {
1378 $langs->load(
"errors");
1380 $this->errors[] = $langs->trans(
"ErrorProdIdIsMandatory", $langs->trans(
'VATIntra')).
' ('.$langs->trans(
"ForbiddenBySetupRules").
')';
1382 } elseif ($key ==
'ACCOUNTANCY_CODE_CUSTOMER' && !empty($this->client)) {
1385 if ($this->
id_prof_exists($keyfield_db, $vallabel, ($this->
id > 0 ? $this->
id : 0))) {
1386 $langs->loadLangs(array(
"errors",
'compta'));
1388 $this->errors[] = $langs->trans(
'CustomerAccountancyCodeShort') .
" " . $langs->trans(
"ErrorProdIdAlreadyExist", $vallabel) .
' (' . $langs->trans(
"ForbiddenBySetupRules") .
')';
1393 if (
getDolGlobalString(
'SOCIETE_ACCOUNTANCY_CODE_CUSTOMER_MANDATORY') && (!isset($vallabel) || trim($vallabel) ===
'')) {
1394 $langs->loadLangs(array(
"errors",
'compta'));
1396 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
'CustomerAccountancyCodeShort')) .
' (' . $langs->trans(
"ForbiddenBySetupRules") .
')';
1398 } elseif ($key ==
'ACCOUNTANCY_CODE_SUPPLIER' && !empty($this->fournisseur)) {
1401 if ($this->
id_prof_exists($keyfield_db, $vallabel, ($this->
id > 0 ? $this->
id : 0))) {
1402 $langs->loadLangs(array(
"errors",
'compta'));
1404 $this->errors[] = $langs->trans(
'SupplierAccountancyCodeShort') .
" " . $langs->trans(
"ErrorProdIdAlreadyExist", $vallabel) .
' (' . $langs->trans(
"ForbiddenBySetupRules") .
')';
1409 if (
getDolGlobalString(
'SOCIETE_ACCOUNTANCY_CODE_SUPPLIER_MANDATORY') && (!isset($vallabel) || trim($vallabel) ===
'')) {
1410 $langs->loadLangs(array(
"errors",
'compta'));
1412 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
'SupplierAccountancyCodeShort')) .
' (' . $langs->trans(
"ForbiddenBySetupRules") .
')';
1437 public function update($id,
User $user, $call_trigger = 1, $allowmodcodeclient = 0, $allowmodcodefournisseur = 0, $action =
'update', $nosyncmember = 1)
1439 global $langs,
$conf, $hookmanager;
1441 require_once DOL_DOCUMENT_ROOT.
'/core/lib/functions2.lib.php';
1446 if (empty($this->country_id) && !empty($this->country_code)) {
1447 $this->country_id =
dol_getIdFromCode($this->db, $this->country_code,
'c_country',
'code',
'rowid');
1452 dol_syslog(get_class($this).
"::Update id=".$id.
" call_trigger=".$call_trigger.
" allowmodcodeclient=".$allowmodcodeclient.
" allowmodcodefournisseur=".$allowmodcodefournisseur);
1458 $this->entity = ((isset($this->entity) && is_numeric($this->entity)) ? $this->entity :
$conf->entity);
1459 $this->
name = $this->
name ? trim($this->
name) : trim((
string) $this->nom);
1460 $this->nom = $this->name;
1461 $this->name_alias = trim((
string) $this->name_alias);
1462 $this->ref_ext = (empty($this->ref_ext) ?
'' : trim($this->ref_ext));
1464 $this->zip = trim((
string) $this->zip);
1465 $this->town = trim((
string) $this->town);
1466 $this->state_id = (is_numeric($this->state_id)) ? (
int) $this->state_id : 0;
1467 $this->country_id = ($this->country_id > 0) ? $this->country_id : 0;
1468 $this->phone = trim((
string) $this->phone);
1469 $this->phone = preg_replace(
"/\s/",
"", $this->phone);
1470 $this->phone = preg_replace(
"/\./",
"", $this->phone);
1471 $this->phone_mobile = trim((
string) $this->phone_mobile);
1472 $this->phone_mobile = preg_replace(
"/\s/",
"", $this->phone_mobile);
1473 $this->phone_mobile = preg_replace(
"/\./",
"", $this->phone_mobile);
1474 $this->fax = trim((
string) $this->fax);
1475 $this->fax = preg_replace(
"/\s/",
"", $this->fax);
1476 $this->fax = preg_replace(
"/\./",
"", $this->fax);
1478 $this->url = $this->url ?
clean_url($this->url, 0) :
'';
1479 $this->note_private = (empty($this->note_private) ?
'' : trim($this->note_private));
1480 $this->note_public = (empty($this->note_public) ?
'' : trim($this->note_public));
1481 $this->idprof1 = trim((
string) $this->idprof1);
1482 $this->idprof2 = trim((
string) $this->idprof2);
1483 $this->idprof3 = trim((
string) $this->idprof3);
1484 $this->idprof4 = trim((
string) $this->idprof4);
1485 $this->idprof5 = (!empty($this->idprof5) ? trim($this->idprof5) :
'');
1486 $this->idprof6 = (!empty($this->idprof6) ? trim($this->idprof6) :
'');
1487 $this->prefix_comm = trim((
string) $this->prefix_comm);
1488 $this->outstanding_limit =
price2num($this->outstanding_limit);
1489 $this->order_min_amount =
price2num($this->order_min_amount);
1490 $this->supplier_order_min_amount =
price2num($this->supplier_order_min_amount);
1492 $this->tva_assuj = (is_numeric($this->tva_assuj)) ? (
int) trim((
string) $this->tva_assuj) : 0;
1494 $this->vat_reverse_charge = empty($this->vat_reverse_charge) ? 0 : 1;
1495 if (empty($this->
status)) {
1499 if (!empty($this->multicurrency_code)) {
1502 if (empty($this->fk_multicurrency)) {
1503 $this->multicurrency_code =
'';
1504 $this->fk_multicurrency = 0;
1508 $this->localtax1_assuj = (int) trim((
string) $this->localtax1_assuj);
1509 $this->localtax2_assuj = (int) trim((
string) $this->localtax2_assuj);
1511 $this->localtax1_value = trim($this->localtax1_value);
1512 $this->localtax2_value = trim($this->localtax2_value);
1514 $this->capital = ($this->capital !=
'') ? (
float)
price2num(trim((
string) $this->capital)) :
null;
1516 $this->effectif_id = (int) $this->effectif_id;
1517 $this->forme_juridique_code = (int) $this->forme_juridique_code;
1520 $this->barcode = trim((
string) $this->barcode);
1523 if ($this->code_client == -1 || $this->code_client ===
'auto') {
1524 $this->get_codeclient($this, 0);
1526 if ($this->code_fournisseur ==
'-1' || $this->code_fournisseur ===
'auto') {
1527 $this->get_codefournisseur($this, 1);
1530 $this->accountancy_code_customer_general = trim((
string) $this->accountancy_code_customer_general);
1531 $this->code_compta_client = trim((
string) $this->code_compta_client);
1532 $this->accountancy_code_supplier_general = trim((
string) $this->accountancy_code_supplier_general);
1533 $this->code_compta_fournisseur = trim((
string) $this->code_compta_fournisseur);
1536 if (!is_numeric($this->client) && !is_numeric($this->fournisseur)) {
1537 $langs->load(
"errors");
1538 $this->error = $langs->trans(
"BadValueForParameterClientOrSupplier");
1543 if (!empty($allowmodcodeclient) && !empty($this->client)) {
1545 if (empty($this->code_compta_client)) {
1556 if (!empty($allowmodcodefournisseur) && !empty($this->fournisseur)) {
1558 if (empty($this->code_compta_fournisseur)) {
1569 $this->webservices_url = empty($this->webservices_url) ?
'' :
clean_url($this->webservices_url, 0);
1570 $this->webservices_key = trim((
string) $this->webservices_key);
1572 $this->accountancy_code_buy = (empty($this->accountancy_code_buy) ?
'' : trim($this->accountancy_code_buy));
1573 $this->accountancy_code_sell = (empty($this->accountancy_code_sell) ?
'' : trim($this->accountancy_code_sell));
1576 $this->fk_incoterms = (int) $this->fk_incoterms;
1577 $this->location_incoterms = trim((
string) $this->location_incoterms);
1584 if ($action !=
'add' && $action !=
'merge') {
1587 $result = $this->
verify();
1591 if (is_array($this->errors)) {
1592 if (in_array(
'ErrorBadCustomerCodeSyntax', $this->errors) && is_object($this->oldcopy) && $this->oldcopy->code_client == $this->code_client) {
1593 if (($key = array_search(
'ErrorBadCustomerCodeSyntax', $this->errors)) !==
false) {
1594 unset($this->errors[$key]);
1597 if (in_array(
'ErrorBadSupplierCodeSyntax', $this->errors) && is_object($this->oldcopy) && $this->oldcopy->code_fournisseur == $this->code_fournisseur) {
1598 if (($key = array_search(
'ErrorBadSupplierCodeSyntax', $this->errors)) !==
false) {
1599 unset($this->errors[$key]);
1602 if (empty($this->errors)) {
1609 dol_syslog(get_class($this).
"::update verify ok or not done");
1611 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"societe SET ";
1612 $sql .=
"entity = ".((int) $this->entity);
1613 $sql .=
",nom = '".$this->db->escape($this->
name).
"'";
1614 $sql .=
",name_alias = '".$this->db->escape($this->name_alias).
"'";
1615 $sql .=
",ref_ext = ".(!empty($this->ref_ext) ?
"'".$this->db->escape($this->ref_ext).
"'" :
"null");
1616 $sql .=
",address = '".$this->db->escape($this->address).
"'";
1618 $sql .=
",zip = ".(!empty($this->zip) ?
"'".$this->db->escape($this->zip).
"'" :
"null");
1619 $sql .=
",town = ".(!empty($this->town) ?
"'".$this->db->escape($this->town).
"'" :
"null");
1621 $sql .=
",fk_departement = ".((!empty($this->state_id) && $this->state_id > 0) ? ((
int) $this->state_id) :
'null');
1622 $sql .=
",fk_pays = ".((!empty($this->country_id) && $this->country_id > 0) ? ((
int) $this->country_id) :
'null');
1624 $sql .=
",phone = ".(!empty($this->phone) ?
"'".$this->db->escape($this->phone).
"'" :
"null");
1625 $sql .=
",phone_mobile = ".(!empty($this->phone_mobile) ?
"'".$this->db->escape($this->phone_mobile).
"'" :
"null");
1626 $sql .=
",fax = ".(!empty($this->fax) ?
"'".$this->db->escape($this->fax).
"'" :
"null");
1627 $sql .=
",email = ".(!empty($this->email) ?
"'".$this->db->escape($this->email).
"'" :
"null");
1628 $sql .=
",socialnetworks = '".$this->db->escape(json_encode($this->socialnetworks)).
"'";
1629 $sql .=
",url = ".(!empty($this->url) ?
"'".$this->db->escape($this->url).
"'" :
"null");
1631 $sql .=
",parent = ".($this->parent > 0 ? $this->parent :
"null");
1633 $sql .=
",note_private = ".(!empty($this->note_private) ?
"'".$this->db->escape($this->note_private).
"'" :
"null");
1634 $sql .=
",note_public = ".(!empty($this->note_public) ?
"'".$this->db->escape($this->note_public).
"'" :
"null");
1636 $sql .=
",siren = '".$this->db->escape($this->idprof1).
"'";
1637 $sql .=
",siret = '".$this->db->escape($this->idprof2).
"'";
1638 $sql .=
",ape = '".$this->db->escape($this->idprof3).
"'";
1639 $sql .=
",idprof4 = '".$this->db->escape($this->idprof4).
"'";
1640 $sql .=
",idprof5 = '".$this->db->escape($this->idprof5).
"'";
1641 $sql .=
",idprof6 = '".$this->db->escape($this->idprof6).
"'";
1643 $sql .=
",tva_assuj = ".($this->tva_assuj !=
'' ?
"'".$this->db->escape($this->tva_assuj).
"'" :
"null");
1644 $sql .=
",tva_intra = '".$this->db->escape($this->tva_intra).
"'";
1646 $sql .=
",vat_reverse_charge = " . ($this->vat_reverse_charge !=
'' ?
"'" . $this->db->escape($this->vat_reverse_charge) .
"'" : 0);
1648 $sql .=
",status = ".((int) $this->
status);
1651 $sql .=
",localtax1_assuj = ".($this->localtax1_assuj !=
'' ?
"'".$this->db->escape($this->localtax1_assuj).
"'" :
"null");
1652 $sql .=
",localtax2_assuj = ".($this->localtax2_assuj !=
'' ?
"'".$this->db->escape($this->localtax2_assuj).
"'" :
"null");
1653 if ($this->localtax1_assuj == 1) {
1654 if ($this->localtax1_value !=
'') {
1655 $sql .=
",localtax1_value =".$this->localtax1_value;
1657 $sql .=
",localtax1_value =0.000";
1660 $sql .=
",localtax1_value =0.000";
1663 if ($this->localtax2_assuj == 1) {
1664 if ($this->localtax2_value !=
'') {
1665 $sql .=
",localtax2_value =".$this->localtax2_value;
1667 $sql .=
",localtax2_value =0.000";
1670 $sql .=
",localtax2_value =0.000";
1673 $sql .=
",capital = ".($this->capital ===
null ?
"null" : $this->capital);
1675 $sql .=
",prefix_comm = ".(!empty($this->prefix_comm) ?
"'".$this->db->escape($this->prefix_comm).
"'" :
"null");
1677 $sql .=
",fk_effectif = ".($this->effectif_id > 0 ? ((int) $this->effectif_id) :
"null");
1678 if (isset($this->stcomm_id)) {
1679 $sql .=
",fk_stcomm=".(int) $this->stcomm_id;
1681 if (isset($this->typent_id)) {
1682 $sql .=
",fk_typent = ".($this->typent_id > 0 ? ((int) $this->typent_id) :
"0");
1685 $sql .=
",fk_forme_juridique = ".(!empty($this->forme_juridique_code) ?
"'".$this->db->escape($this->forme_juridique_code).
"'" :
"null");
1687 $sql .=
",mode_reglement = ".(!empty($this->mode_reglement_id) ?
"'".$this->db->escape($this->mode_reglement_id).
"'" :
"null");
1688 $sql .=
",cond_reglement = ".(!empty($this->cond_reglement_id) ?
"'".$this->db->escape($this->cond_reglement_id).
"'" :
"null");
1689 $sql .=
",deposit_percent = ".(!empty($this->deposit_percent) ?
"'".$this->db->escape($this->deposit_percent).
"'" :
"null");
1690 $sql .=
",transport_mode = ".(!empty($this->transport_mode_id) ?
"'".$this->db->escape($this->transport_mode_id).
"'" :
"null");
1691 $sql .=
",mode_reglement_supplier = ".(!empty($this->mode_reglement_supplier_id) ?
"'".$this->db->escape($this->mode_reglement_supplier_id).
"'" :
"null");
1692 $sql .=
",cond_reglement_supplier = ".(!empty($this->cond_reglement_supplier_id) ?
"'".$this->db->escape($this->cond_reglement_supplier_id).
"'" :
"null");
1693 $sql .=
",transport_mode_supplier = ".(!empty($this->transport_mode_supplier_id) ?
"'".$this->db->escape($this->transport_mode_supplier_id).
"'" :
"null");
1694 $sql .=
",fk_shipping_method = ".(!empty($this->shipping_method_id) ?
"'".$this->db->escape($this->shipping_method_id).
"'" :
"null");
1696 $sql .=
",client = ".(!empty($this->client) ? $this->client : 0);
1697 $sql .=
",fournisseur = ".(!empty($this->fournisseur) ? $this->fournisseur : 0);
1698 $sql .=
",barcode = ".(!empty($this->barcode) ?
"'".$this->db->escape($this->barcode).
"'" :
"null");
1699 $sql .=
",default_lang = ".(!empty($this->default_lang) ?
"'".$this->db->escape($this->default_lang).
"'" :
"null");
1700 $sql .=
",logo = ".(!empty($this->logo) ?
"'".$this->db->escape($this->logo).
"'" :
"null");
1701 $sql .=
",logo_squarred = ".(!empty($this->logo_squarred) ?
"'".$this->db->escape($this->logo_squarred).
"'" :
"null");
1702 $sql .=
",outstanding_limit= ".($this->outstanding_limit !=
'' ? $this->outstanding_limit :
'null');
1703 $sql .=
",order_min_amount= ".($this->order_min_amount !=
'' ? $this->order_min_amount :
'null');
1704 $sql .=
",supplier_order_min_amount= ".($this->supplier_order_min_amount !=
'' ? $this->supplier_order_min_amount :
'null');
1705 $sql .=
",fk_prospectlevel='".$this->db->escape($this->fk_prospectlevel).
"'";
1707 $sql .=
", accountancy_code_buy = '" . $this->db->escape($this->accountancy_code_buy) .
"'";
1708 $sql .=
", accountancy_code_sell= '" . $this->db->escape($this->accountancy_code_sell) .
"'";
1710 $sql .=
", accountancy_code_customer_general = ".(!empty($this->accountancy_code_customer_general) ?
"'".$this->db->escape($this->accountancy_code_customer_general).
"'" :
"null");
1711 $sql .=
", code_compta = ".(!empty($this->code_compta_client) ?
"'".$this->db->escape($this->code_compta_client).
"'" :
"null");
1715 $sql .=
", accountancy_code_supplier_general = ".(!empty($this->accountancy_code_supplier_general) ?
"'".$this->db->escape($this->accountancy_code_supplier_general).
"'" :
"null");
1716 $sql .=
", code_compta_fournisseur = ".(($this->code_compta_fournisseur !=
"") ?
"'".$this->db->escape($this->code_compta_fournisseur).
"'" :
"null");
1719 $sql .=
",webservices_url = ".(!empty($this->webservices_url) ?
"'".$this->db->escape($this->webservices_url).
"'" :
"null");
1720 $sql .=
",webservices_key = ".(!empty($this->webservices_key) ?
"'".$this->db->escape($this->webservices_key).
"'" :
"null");
1723 $sql .=
", fk_incoterms = ".((int) $this->fk_incoterms);
1724 $sql .=
", location_incoterms = ".(!empty($this->location_incoterms) ?
"'".$this->db->escape($this->location_incoterms).
"'" :
"null");
1727 $sql .=
", code_client = ".(!empty($this->code_client) ?
"'".$this->db->escape($this->code_client).
"'" :
"null");
1731 $sql .=
", code_fournisseur = ".(!empty($this->code_fournisseur) ?
"'".$this->db->escape($this->code_fournisseur).
"'" :
"null");
1733 $sql .=
", fk_user_modif = ".($user->id > 0 ? $user->id :
"null");
1734 $sql .=
", fk_multicurrency = ".(int) $this->fk_multicurrency;
1735 $sql .=
", multicurrency_code = '".$this->db->escape($this->multicurrency_code).
"'";
1736 $sql .=
", model_pdf = '".$this->db->escape($this->model_pdf).
"'";
1737 $sql .=
" WHERE rowid = ".(int) $id;
1739 $resql = $this->db->query($sql);
1741 if (is_object($this->oldcopy)) {
1742 if ($this->oldcopy->country_id != $this->country_id) {
1743 unset($this->country_code);
1744 unset($this->country);
1746 if ($this->oldcopy->state_id != $this->state_id) {
1747 unset($this->state_code);
1748 unset($this->state);
1751 unset($this->country_code);
1752 unset($this->country);
1753 unset($this->state_code);
1754 unset($this->state);
1757 $nbrowsaffected = $this->db->affected_rows($resql);
1759 if (!$error && $nbrowsaffected) {
1761 if (!$nosyncmember && isModEnabled(
'member')) {
1762 require_once DOL_DOCUMENT_ROOT.
'/adherents/class/adherent.class.php';
1764 dol_syslog(get_class($this).
"::update update linked member");
1766 $lmember =
new Adherent($this->db);
1767 $result = $lmember->fetch(0, 0, $this->
id);
1770 $lmember->company = $this->name;
1773 $lmember->address = $this->address;
1774 $lmember->zip = $this->zip;
1775 $lmember->town = $this->town;
1776 $lmember->email = $this->email;
1777 $lmember->socialnetworks = $this->socialnetworks;
1778 $lmember->phone = $this->phone;
1779 $lmember->state_id = $this->state_id;
1780 $lmember->country_id = $this->country_id;
1781 $lmember->default_lang = $this->default_lang;
1783 $result = $lmember->update($user, 0, 1, 1, 1);
1785 $this->error = $lmember->error;
1786 $this->errors = array_merge($this->errors, $lmember->errors);
1787 dol_syslog(get_class($this).
"::update ".$this->error, LOG_ERR);
1790 } elseif ($result < 0) {
1791 $this->error = $lmember->error;
1801 $this->db->query(
"DELETE FROM ".MAIN_DB_PREFIX.
"societe_perentity WHERE fk_soc = ".((
int) $this->id).
" AND entity = ".((
int)
$conf->entity));
1803 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"societe_perentity (";
1806 $sql .=
", vat_reverse_charge";
1807 $sql .=
", accountancy_code_customer_general";
1808 $sql .=
", accountancy_code_customer";
1809 $sql .=
", accountancy_code_supplier_general";
1810 $sql .=
", accountancy_code_supplier";
1811 $sql .=
", accountancy_code_buy";
1812 $sql .=
", accountancy_code_sell";
1813 $sql .=
") VALUES (";
1815 $sql .=
", ".$conf->entity;
1816 $sql .=
", ".(empty($this->vat_reverse_charge) ?
'0' :
'1');
1817 $sql .=
", '".$this->db->escape($this->accountancy_code_customer_general).
"'";
1818 $sql .=
", '".$this->db->escape($this->code_compta_client).
"'";
1819 $sql .=
", '".$this->db->escape($this->accountancy_code_supplier_general).
"'";
1820 $sql .=
", '".$this->db->escape($this->code_compta_fournisseur).
"'";
1821 $sql .=
", '".$this->db->escape($this->accountancy_code_buy).
"'";
1822 $sql .=
", '".$this->db->escape($this->accountancy_code_sell).
"'";
1824 $result = $this->db->query($sql);
1827 $this->error =
'ErrorFailedToUpdateAccountancyForEntity';
1846 if (!$error && $call_trigger) {
1848 $result = $this->
call_trigger(
'COMPANY_MODIFY', $user);
1856 dol_syslog(get_class($this).
"::Update success");
1857 $this->db->commit();
1860 $this->db->rollback();
1864 if ($this->db->errno() ==
'DB_ERROR_RECORD_ALREADY_EXISTS') {
1866 $this->error = $langs->trans(
"ErrorDuplicateField");
1869 $this->error = $this->db->lasterror();
1872 $this->db->rollback();
1876 $this->db->rollback();
1877 dol_syslog(get_class($this).
"::Update fails verify ".implode(
',', $this->errors), LOG_WARNING);
1901 public function fetch($rowid, $ref =
'', $ref_ext =
'', $barcode =
'', $idprof1 =
'', $idprof2 =
'', $idprof3 =
'', $idprof4 =
'', $idprof5 =
'', $idprof6 =
'', $email =
'', $ref_alias =
'', $is_client = 0, $is_supplier = 0)
1906 if (empty($rowid) && empty($ref) && empty($ref_ext) && empty($barcode) && empty($idprof1) && empty($idprof2) && empty($idprof3) && empty($idprof4) && empty($idprof5) && empty($idprof6) && empty($email) && empty($ref_alias)) {
1910 $sql =
'SELECT s.rowid, s.nom as name, s.name_alias, s.entity, s.ref_ext, s.address, s.datec as date_creation, s.prefix_comm';
1911 $sql .=
', s.status, s.fk_warehouse';
1912 $sql .=
', s.price_level';
1913 $sql .=
', s.tms as date_modification, s.fk_user_creat, s.fk_user_modif';
1914 $sql .=
', s.phone, s.phone_mobile, s.fax, s.email';
1915 $sql .=
', s.socialnetworks';
1916 $sql .=
', s.url, s.zip, s.town, s.note_private, s.note_public, s.client, s.fournisseur';
1917 $sql .=
', s.siren as idprof1, s.siret as idprof2, s.ape as idprof3, s.idprof4, s.idprof5, s.idprof6';
1918 $sql .=
', s.capital, s.tva_intra';
1919 $sql .=
', s.fk_typent as typent_id';
1920 $sql .=
', s.fk_effectif as effectif_id';
1921 $sql .=
', s.fk_forme_juridique as forme_juridique_code';
1922 $sql .=
', s.webservices_url, s.webservices_key, s.model_pdf, s.last_main_doc';
1924 $sql .=
', s.accountancy_code_customer_general, s.code_compta';
1925 $sql .=
', s.accountancy_code_supplier_general, s.code_compta_fournisseur';
1926 $sql .=
', s.accountancy_code_buy, s.accountancy_code_sell';
1927 $sql .=
', s.vat_reverse_charge as soc_vat_reverse_charge';
1929 $sql .=
', spe.accountancy_code_customer_general, spe.accountancy_code_customer as code_compta';
1930 $sql .=
', spe.accountancy_code_supplier_general, spe.accountancy_code_supplier as code_compta_fournisseur';
1931 $sql .=
', spe.accountancy_code_buy, spe.accountancy_code_sell';
1932 $sql .=
', spe.vat_reverse_charge as spe_vat_reverse_charge';
1934 $sql .=
', s.code_client, s.code_fournisseur, s.parent, s.barcode';
1935 $sql .=
', s.fk_departement as state_id, s.fk_pays as country_id, s.fk_stcomm, s.mode_reglement, s.cond_reglement, s.deposit_percent, s.transport_mode';
1936 $sql .=
', s.fk_account, s.tva_assuj';
1937 $sql .=
', s.mode_reglement_supplier, s.cond_reglement_supplier, s.transport_mode_supplier';
1938 $sql .=
', s.localtax1_assuj, s.localtax1_value, s.localtax2_assuj, s.localtax2_value, s.fk_prospectlevel, s.default_lang, s.logo, s.logo_squarred';
1939 $sql .=
', s.fk_shipping_method';
1940 $sql .=
', s.outstanding_limit, s.import_key, s.canvas, s.fk_incoterms, s.location_incoterms';
1941 $sql .=
', s.order_min_amount, s.supplier_order_min_amount';
1942 $sql .=
', s.fk_multicurrency, s.multicurrency_code';
1943 $sql .=
', fj.libelle as forme_juridique';
1944 $sql .=
', e.libelle as effectif';
1945 $sql .=
', c.code as country_code, c.label as country';
1946 $sql .=
', d.code_departement as state_code, d.nom as state';
1947 $sql .=
', r.rowid as region_id, r.code_region as region_code';
1948 $sql .=
', st.libelle as stcomm, st.picto as stcomm_picto';
1949 $sql .=
', te.code as typent_code';
1950 $sql .=
', i.libelle as label_incoterms';
1951 if (!isModEnabled(
'multicompany')) {
1952 $sql .=
', s.remise_client, s.remise_supplier';
1954 $sql .=
', sr.remise_client, sr2.remise_supplier';
1956 $sql .=
' FROM '.MAIN_DB_PREFIX.
'societe as s';
1958 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe_perentity as spe ON spe.fk_soc = s.rowid AND spe.entity = ".((int)
$conf->entity);
1960 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_effectif as e ON s.fk_effectif = e.id';
1961 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_country as c ON s.fk_pays = c.rowid';
1962 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_stcomm as st ON s.fk_stcomm = st.id';
1963 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_forme_juridique as fj ON s.fk_forme_juridique = fj.code';
1964 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_departements as d ON s.fk_departement = d.rowid';
1965 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_regions as r ON d.fk_region = r.code_region ';
1966 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_typent as te ON s.fk_typent = te.id';
1967 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_incoterms as i ON s.fk_incoterms = i.rowid';
1970 if (isModEnabled(
'multicompany')) {
1971 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'societe_remise as sr ON sr.rowid = (SELECT MAX(rowid) FROM '.MAIN_DB_PREFIX.
'societe_remise WHERE fk_soc = s.rowid AND entity IN ('.
getEntity(
'discount').
'))';
1972 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'societe_remise_supplier as sr2 ON sr2.rowid = (SELECT MAX(rowid) FROM '.MAIN_DB_PREFIX.
'societe_remise_supplier WHERE fk_soc = s.rowid AND entity IN ('.
getEntity(
'discount').
'))';
1974 $sql .=
' WHERE s.entity IN ('.getEntity($this->element).
')';
1978 $sql .=
' AND s.client > 0';
1981 $sql .=
' AND s.fournisseur > 0';
1985 $sql .=
' AND s.rowid = '.((int) $rowid);
1988 $sql .=
" AND s.nom = '".$this->db->escape($ref).
"'";
1991 $sql .=
" AND s.name_alias = '".$this->db->escape($ref_alias).
"'";
1994 $sql .=
" AND s.ref_ext = '".$this->db->escape($ref_ext).
"'";
1997 $sql .=
" AND s.barcode = '".$this->db->escape($barcode).
"'";
2000 $sql .=
" AND s.siren = '".$this->db->escape($idprof1).
"'";
2003 $sql .=
" AND s.siret = '".$this->db->escape($idprof2).
"'";
2006 $sql .=
" AND s.ape = '".$this->db->escape($idprof3).
"'";
2009 $sql .=
" AND s.idprof4 = '".$this->db->escape($idprof4).
"'";
2012 $sql .=
" AND s.idprof5 = '".$this->db->escape($idprof5).
"'";
2015 $sql .=
" AND s.idprof6 = '".$this->db->escape($idprof6).
"'";
2018 $sql .=
" AND s.email = '".$this->db->escape($email).
"'";
2021 $resql = $this->db->query($sql);
2023 $num = $this->db->num_rows($resql);
2025 $this->error =
'Fetch found several records. Rename one of thirdparties to avoid duplicate.';
2029 $obj = $this->db->fetch_object($resql);
2031 $this->
id = $obj->rowid;
2032 $this->entity = $obj->entity;
2033 $this->canvas = $obj->canvas;
2035 $this->
ref = $obj->name;
2036 $this->
name = $obj->name;
2037 $this->nom = $obj->name;
2038 $this->name_alias = $obj->name_alias;
2039 $this->ref_ext = $obj->ref_ext;
2041 $this->date_creation = $this->db->jdate($obj->date_creation);
2042 $this->date_modification = $this->db->jdate($obj->date_modification);
2043 $this->user_creation_id = $obj->fk_user_creat;
2044 $this->user_modification_id = $obj->fk_user_modif;
2046 $this->
address = $obj->address;
2047 $this->zip = $obj->zip;
2048 $this->town = $obj->town;
2050 $this->country_id = $obj->country_id;
2051 $this->country_code = $obj->country_id ? $obj->country_code :
'';
2052 $this->country = $obj->country_id ? (($langs->transnoentities(
'Country'.$obj->country_code) !=
'Country'.$obj->country_code) ? $langs->transnoentities(
'Country'.$obj->country_code) : $obj->country) :
'';
2054 $this->state_id = $obj->state_id;
2055 $this->state_code = $obj->state_code;
2056 $this->region_id = $obj->region_id;
2057 $this->region_code = $obj->region_code;
2058 $this->state = ($obj->state !=
'-' ? $obj->state :
'');
2060 $transcode = $langs->trans(
'StatusProspect'.$obj->fk_stcomm);
2061 $label = ($transcode !=
'StatusProspect'.$obj->fk_stcomm ? $transcode : $obj->stcomm);
2062 $this->stcomm_id = $obj->fk_stcomm;
2063 $this->status_prospect_label = $label;
2064 $this->stcomm_picto = $obj->stcomm_picto;
2066 $this->
email = $obj->email;
2067 $this->socialnetworks = ($obj->socialnetworks ? (array) json_decode($obj->socialnetworks,
true) : array());
2069 $this->url = $obj->url;
2070 $this->phone = $obj->phone;
2071 $this->phone_mobile = $obj->phone_mobile;
2072 $this->fax = $obj->fax;
2074 $this->parent = $obj->parent;
2076 $this->idprof1 = $obj->idprof1;
2077 $this->idprof2 = $obj->idprof2;
2078 $this->idprof3 = $obj->idprof3;
2079 $this->idprof4 = $obj->idprof4;
2080 $this->idprof5 = $obj->idprof5;
2081 $this->idprof6 = $obj->idprof6;
2083 $this->capital = $obj->capital;
2085 $this->code_client = $obj->code_client;
2086 $this->code_fournisseur = $obj->code_fournisseur;
2088 $this->accountancy_code_customer_general = $obj->accountancy_code_customer_general;
2089 $this->code_compta_client = $obj->code_compta;
2090 $this->accountancy_code_supplier_general = $obj->accountancy_code_supplier_general;
2091 $this->code_compta_fournisseur = $obj->code_compta_fournisseur;
2093 $this->barcode = $obj->barcode;
2095 $this->tva_assuj = $obj->tva_assuj;
2096 $this->tva_intra = $obj->tva_intra;
2098 if (!empty($obj->spe_vat_reverse_charge)) {
2099 $this->vat_reverse_charge = $obj->spe_vat_reverse_charge;
2100 } elseif (!empty($obj->soc_vat_reverse_charge)) {
2101 $this->vat_reverse_charge = $obj->soc_vat_reverse_charge;
2103 $this->vat_reverse_charge = 0;
2106 $this->
status = $obj->status;
2109 $this->localtax1_assuj = $obj->localtax1_assuj;
2110 $this->localtax2_assuj = $obj->localtax2_assuj;
2112 $this->localtax1_value = $obj->localtax1_value;
2113 $this->localtax2_value = $obj->localtax2_value;
2115 $this->typent_id = $obj->typent_id;
2116 $this->typent_code = $obj->typent_code;
2118 $this->effectif_id = $obj->effectif_id;
2119 $this->effectif = $obj->effectif_id ? $obj->effectif :
'';
2121 $this->forme_juridique_code = $obj->forme_juridique_code;
2122 $this->forme_juridique = $obj->forme_juridique_code ? $obj->forme_juridique :
'';
2124 $this->fk_prospectlevel = $obj->fk_prospectlevel;
2126 $this->prefix_comm = $obj->prefix_comm;
2128 $this->remise_percent = $obj->remise_client ?
price2num($obj->remise_client) : 0;
2129 $this->remise_supplier_percent = $obj->remise_supplier;
2131 $this->mode_reglement_id = $obj->mode_reglement;
2132 $this->cond_reglement_id = $obj->cond_reglement;
2133 $this->deposit_percent = $obj->deposit_percent;
2134 $this->transport_mode_id = $obj->transport_mode;
2135 $this->mode_reglement_supplier_id = $obj->mode_reglement_supplier;
2136 $this->cond_reglement_supplier_id = $obj->cond_reglement_supplier;
2137 $this->transport_mode_supplier_id = $obj->transport_mode_supplier;
2138 $this->shipping_method_id = ($obj->fk_shipping_method > 0) ? $obj->fk_shipping_method :
null;
2139 $this->fk_account = $obj->fk_account;
2141 $this->client = $obj->client;
2142 $this->fournisseur = $obj->fournisseur;
2144 $this->note = $obj->note_private;
2145 $this->note_private = $obj->note_private;
2146 $this->note_public = $obj->note_public;
2147 $this->model_pdf = $obj->model_pdf;
2148 $this->default_lang = $obj->default_lang;
2149 $this->logo = $obj->logo;
2150 $this->logo_squarred = $obj->logo_squarred;
2152 $this->webservices_url = $obj->webservices_url;
2153 $this->webservices_key = $obj->webservices_key;
2155 $this->accountancy_code_buy = $obj->accountancy_code_buy;
2156 $this->accountancy_code_sell = $obj->accountancy_code_sell;
2158 $this->outstanding_limit = $obj->outstanding_limit;
2159 $this->order_min_amount = $obj->order_min_amount;
2160 $this->supplier_order_min_amount = $obj->supplier_order_min_amount;
2163 $this->price_level = $obj->price_level;
2166 $this->fk_warehouse = $obj->fk_warehouse;
2168 $this->import_key = $obj->import_key;
2171 $this->fk_incoterms = $obj->fk_incoterms;
2172 $this->location_incoterms = $obj->location_incoterms;
2173 $this->label_incoterms = $obj->label_incoterms;
2176 $this->fk_multicurrency = $obj->fk_multicurrency;
2177 $this->multicurrency_code = $obj->multicurrency_code;
2180 $this->model_pdf = $obj->model_pdf;
2181 $this->last_main_doc = $obj->last_main_doc;
2183 $result = $this->id;
2191 $this->db->free($resql);
2193 $this->error = $this->db->lasterror();
2194 $this->errors[] = $this->db->lasterror();
2200 $this->price_level = 1;
2226 public function findNearest($rowid = 0, $ref =
'', $ref_ext =
'', $barcode =
'', $idprof1 =
'', $idprof2 =
'', $idprof3 =
'', $idprof4 =
'', $idprof5 =
'', $idprof6 =
'', $email =
'', $ref_alias =
'', $is_client = 0, $is_supplier = 0)
2239 $tmpthirdparty =
new Societe($this->db);
2240 $result = $tmpthirdparty->fetch($rowid, $ref, $ref_ext, $barcode, $idprof1, $idprof2, $idprof3, $idprof4, $idprof5, $idprof6, $email, $ref_alias, $is_client, $is_supplier);
2253 public function delete($id, $fuser =
null, $call_trigger = 1)
2255 global
$conf, $user;
2257 if (empty($fuser)) {
2261 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
2263 $entity = isset($this->entity) ? $this->entity :
$conf->entity;
2265 dol_syslog(get_class($this).
"::delete", LOG_DEBUG);
2270 if (empty($objectisused)) {
2274 if (!$error && $call_trigger) {
2276 $result = $this->
call_trigger(
'COMPANY_DELETE', $fuser);
2284 require_once DOL_DOCUMENT_ROOT.
'/categories/class/categorie.class.php';
2286 $toute_categs = array();
2289 $toute_categs[
'customer'] = $static_cat->containing($this->
id, Categorie::TYPE_CUSTOMER);
2290 $toute_categs[
'supplier'] = $static_cat->containing($this->
id, Categorie::TYPE_SUPPLIER);
2293 foreach ($toute_categs as $type => $categs_type) {
2294 foreach ($categs_type as $cat) {
2295 $cat->del_type($this, $type);
2301 foreach ($this->childtablesoncascade as $tabletodelete) {
2302 $deleteFromObject = explode(
':', $tabletodelete, 4);
2303 if (count($deleteFromObject) >= 2) {
2304 $className = str_replace(
'@',
'', $deleteFromObject[0]);
2305 $filepath = $deleteFromObject[1];
2306 $columnName = $deleteFromObject[2];
2308 $child_object =
new $className($this->db);
2309 '@phan-var-force CommonObject $child_object';
2310 $result = $child_object->deleteByParentField($id, $columnName);
2313 $this->errors[] = $child_object->error;
2318 $this->errors[] =
'Cannot include child class file '.$filepath;
2322 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.$tabletodelete;
2323 $sql .=
" WHERE fk_soc = ".((int) $id);
2324 if (!$this->db->query($sql)) {
2326 $this->errors[] = $this->db->lasterror();
2338 dol_syslog(get_class($this).
"::delete error -3 ".$this->error, LOG_ERR);
2344 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"societe";
2345 $sql .=
" SET parent = NULL";
2346 $sql .=
" WHERE parent = ".((int) $id);
2347 if (!$this->db->query($sql)) {
2349 $this->errors[] = $this->db->lasterror();
2356 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"societe_perentity";
2357 $sql .=
" WHERE fk_soc = ".((int) $id);
2358 if (!$this->db->query($sql)) {
2360 $this->errors[] = $this->db->lasterror();
2364 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"societe";
2365 $sql .=
" WHERE rowid = ".((int) $id);
2366 if (!$this->db->query($sql)) {
2368 $this->errors[] = $this->db->lasterror();
2373 $this->db->commit();
2376 if (!empty(
$conf->societe->multidir_output[$entity])) {
2377 $docdir =
$conf->societe->multidir_output[$entity].
"/".$id;
2386 $this->db->rollback();
2390 dol_syslog(
"Can't remove thirdparty with id ".$id.
". There are ".$objectisused.
" children", LOG_WARNING);
2406 dol_syslog(get_class($this).
"::set_as_client is deprecated use setAsCustomer instead", LOG_NOTICE);
2420 if (($this->client == 2 || $this->client == 3) && !
getDolGlobalInt(
'SOCIETE_DISABLE_PROSPECTSCUSTOMERS')) {
2423 $sql =
"UPDATE ".MAIN_DB_PREFIX.$this->table_element;
2424 $sql .=
" SET client = ".((int) $newclient);
2425 $sql .=
" WHERE rowid = ".((int) $this->
id);
2427 $resql = $this->db->query($sql);
2429 $this->client = $newclient;
2450 global
$conf, $langs;
2453 $note = trim($note);
2455 $this->error = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"NoteReason"));
2459 dol_syslog(get_class($this).
"::set_remise_client ".$remise.
", ".$note.
", ".$user->id);
2467 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"societe ";
2468 $sql .=
" SET remise_client = '".$this->db->escape($remise).
"'";
2469 $sql .=
" WHERE rowid = ".((int) $this->
id);
2470 $resql = $this->db->query($sql);
2472 $this->db->rollback();
2473 $this->error = $this->db->error();
2478 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"societe_remise";
2479 $sql .=
" (entity, datec, fk_soc, remise_client, note, fk_user_author)";
2480 $sql .=
" VALUES (".((int)
$conf->entity).
", '".$this->db->idate($now).
"', ".((int) $this->
id).
", '".$this->db->escape($remise).
"',";
2481 $sql .=
" '".$this->db->escape($note).
"',";
2482 $sql .=
" ".((int) $user->id);
2485 $resql = $this->db->query($sql);
2487 $this->db->rollback();
2488 $this->error = $this->db->lasterror();
2492 $this->db->commit();
2511 global
$conf, $langs;
2514 $note = trim($note);
2516 $this->error = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"NoteReason"));
2520 dol_syslog(get_class($this).
"::set_remise_supplier ".$remise.
", ".$note.
", ".$user->id);
2528 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"societe ";
2529 $sql .=
" SET remise_supplier = '".$this->db->escape($remise).
"'";
2530 $sql .=
" WHERE rowid = ".((int) $this->
id);
2531 $resql = $this->db->query($sql);
2533 $this->db->rollback();
2534 $this->error = $this->db->error();
2539 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"societe_remise_supplier";
2540 $sql .=
" (entity, datec, fk_soc, remise_supplier, note, fk_user_author)";
2541 $sql .=
" VALUES (".((int)
$conf->entity).
", '".$this->db->idate($now).
"', ".((int) $this->
id).
", '".$this->db->escape($remise).
"',";
2542 $sql .=
" '".$this->db->escape($note).
"',";
2543 $sql .=
" ".((int) $user->id);
2546 $resql = $this->db->query($sql);
2548 $this->db->rollback();
2549 $this->error = $this->db->lasterror();
2553 $this->db->commit();
2572 public function set_remise_except($remise,
User $user, $desc, $vatrate =
'', $discount_type = 0, $price_base_type =
'HT')
2579 $desc = trim($desc);
2582 if (!($remise > 0)) {
2583 $this->error = $langs->trans(
"ErrorWrongValueForParameter",
"1");
2587 $this->error = $langs->trans(
"ErrorWrongValueForParameter",
"3");
2591 if ($this->
id > 0) {
2595 if (preg_match(
'/\((.*)\)/', $vatrate, $reg)) {
2596 $vat_src_code = $reg[1];
2597 $vatrate = preg_replace(
'/\s*\(.*\)/',
'', $vatrate);
2600 require_once DOL_DOCUMENT_ROOT.
'/core/class/discount.class.php';
2603 $discount->fk_soc = $this->id;
2604 $discount->socid = $this->id;
2606 $discount->discount_type = $discount_type;
2608 if ($price_base_type ==
'TTC') {
2609 $discount->amount_ttc = $discount->multicurrency_amount_ttc =
price2num($remise,
'MT');
2610 $discount->amount_ht = $discount->multicurrency_amount_ht =
price2num((
float) $remise / (1 + (
float) $vatrate / 100),
'MT');
2611 $discount->amount_tva = $discount->multicurrency_amount_tva =
price2num((
float) $discount->amount_ttc - (
float) $discount->amount_ht,
'MT');
2613 $discount->amount_ht = $discount->multicurrency_amount_ht =
price2num($remise,
'MT');
2614 $discount->amount_tva = $discount->multicurrency_amount_tva =
price2num((
float) $remise * (
float) $vatrate / 100,
'MT');
2615 $discount->amount_ttc = $discount->multicurrency_amount_ttc =
price2num((
float) $discount->amount_ht + (
float) $discount->amount_tva,
'MT');
2618 $discount->tva_tx = (float)
price2num($vatrate);
2619 $discount->vat_src_code = $vat_src_code;
2621 $discount->description = $desc;
2623 $result = $discount->create($user);
2627 $this->error = $discount->error;
2646 require_once DOL_DOCUMENT_ROOT.
'/core/class/discount.class.php';
2649 $result = $discountstatic->getAvailableDiscounts($this, $user, $filter, $maxvalue, $discount_type);
2653 $this->error = $discountstatic->error;
2671 $reparray = array();
2673 $sql =
"SELECT u.rowid, u.login, u.lastname, u.firstname, u.office_phone, u.job, u.email, u.statut as status, u.entity, u.photo, u.gender";
2674 $sql .=
", u.office_fax, u.user_mobile, u.personal_mobile";
2675 $sql .=
" FROM ".MAIN_DB_PREFIX.
"societe_commerciaux as sc, ".MAIN_DB_PREFIX.
"user as u";
2677 if (isModEnabled(
'multicompany') &&
getDolGlobalString(
'MULTICOMPANY_TRANSVERSE_MODE')) {
2678 $sql .=
" WHERE u.rowid IN (SELECT ug.fk_user FROM ".$this->db->prefix().
"usergroup_user as ug WHERE ug.entity IN (".
getEntity(
'usergroup').
"))";
2680 $sql .=
" WHERE entity IN (0, ".$this->db->sanitize(
$conf->entity).
")";
2683 $sql .=
" AND u.rowid = sc.fk_user AND sc.fk_soc = ".((int) $this->
id);
2684 if (empty($sortfield) && empty($sortorder)) {
2685 $sortfield =
'u.lastname,u.firstname';
2686 $sortorder =
'ASC,ASC';
2688 $sql .= $this->db->order($sortfield, $sortorder);
2690 $resql = $this->db->query($sql);
2692 $num = $this->db->num_rows($resql);
2695 $obj = $this->db->fetch_object($resql);
2698 $reparray[$i][
'id'] = $obj->rowid;
2699 $reparray[$i][
'lastname'] = $obj->lastname;
2700 $reparray[$i][
'firstname'] = $obj->firstname;
2701 $reparray[$i][
'email'] = $obj->email;
2702 $reparray[$i][
'phone'] = $obj->office_phone;
2703 $reparray[$i][
'office_phone'] = $obj->office_phone;
2704 $reparray[$i][
'office_fax'] = $obj->office_fax;
2705 $reparray[$i][
'user_mobile'] = $obj->user_mobile;
2706 $reparray[$i][
'personal_mobile'] = $obj->personal_mobile;
2707 $reparray[$i][
'job'] = $obj->job;
2708 $reparray[$i][
'statut'] = $obj->status;
2709 $reparray[$i][
'status'] = $obj->status;
2710 $reparray[$i][
'entity'] = $obj->entity;
2711 $reparray[$i][
'login'] = $obj->login;
2712 $reparray[$i][
'photo'] = $obj->photo;
2713 $reparray[$i][
'gender'] = $obj->gender;
2715 $reparray[] = $obj->rowid;
2738 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"societe";
2739 $sql .=
" SET price_level = ".((int) $price_level);
2740 $sql .=
" WHERE rowid = ".((int) $this->
id);
2742 if (!$this->db->query($sql)) {
2747 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"societe_prices";
2748 $sql .=
" (datec, fk_soc, price_level, fk_user_author)";
2749 $sql .=
" VALUES ('".$this->db->idate($now).
"', ".((int) $this->
id).
", ".((int) $price_level).
", ".((int) $user->id).
")";
2751 if (!$this->db->query($sql)) {
2773 if ($this->
id > 0 && $commid > 0) {
2777 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"societe_commerciaux";
2778 $sql .=
" WHERE fk_soc = ".((int) $this->
id).
" AND fk_user = ".((int) $commid);
2780 $resql = $this->db->query($sql);
2782 dol_syslog(get_class($this).
"::add_commercial Error ".$this->db->lasterror());
2788 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"societe_commerciaux";
2789 $sql .=
" (fk_soc, fk_user)";
2790 $sql .=
" VALUES (".((int) $this->
id).
", ".((int) $commid).
")";
2792 $resql = $this->db->query($sql);
2794 dol_syslog(get_class($this).
"::add_commercial Error ".$this->db->lasterror());
2800 $this->context = array(
'commercial_modified' => $commid);
2802 $result = $this->
call_trigger(
'COMPANY_LINK_SALE_REPRESENTATIVE', $user);
2809 $this->db->commit();
2812 $this->db->rollback();
2832 $this->context = array(
'commercial_modified' => $commid);
2834 $result = $this->
call_trigger(
'COMPANY_UNLINK_SALE_REPRESENTATIVE', $user);
2839 if ($this->
id > 0 && $commid > 0) {
2840 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"societe_commerciaux ";
2841 $sql .=
" WHERE fk_soc = ".((int) $this->
id).
" AND fk_user = ".((int) $commid);
2843 if (!$this->db->query($sql)) {
2845 dol_syslog(get_class($this).
"::del_commercial Erreur");
2865 global
$conf, $langs, $user;
2867 $langs->loadLangs([
'companies',
'commercial']);
2871 $option = $params[
'option'] ??
'';
2872 $nofetch = !empty($params[
'nofetch']);
2874 $noaliasinname = (empty($params[
'noaliasinname']) ? 0 : $params[
'noaliasinname']);
2877 return [
'optimize' => $langs->trans(
"ShowCompany")];
2880 if (!empty($this->logo) && class_exists(
'Form')) {
2881 $photo =
'<div class="photointooltip floatright">';
2882 $photo .=
Form::showphoto(
'societe', $this, 0, 40, 0,
'photoref',
'mini', 0);
2884 $datas[
'photo'] = $photo;
2891 $datas[
'divopen'] =
'<div class="centpercent">';
2893 if ($option ==
'customer' || $option ==
'compta' || $option ==
'category') {
2894 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"Customer").
'</u>';
2895 } elseif ($option ==
'prospect' && !
getDolGlobalString(
'SOCIETE_DISABLE_PROSPECTS')) {
2896 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"Prospect").
'</u>';
2897 } elseif ($option ==
'supplier' || $option ==
'category_supplier') {
2898 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"Supplier").
'</u>';
2899 } elseif ($option ==
'agenda') {
2900 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"ThirdParty").
'</u>';
2901 } elseif ($option ==
'project') {
2902 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"ThirdParty").
'</u>';
2903 } elseif ($option ==
'margin') {
2904 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"ThirdParty").
'</u>';
2905 } elseif ($option ==
'contact') {
2906 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"ThirdParty").
'</u>';
2907 } elseif ($option ==
'ban') {
2908 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"ThirdParty").
'</u>';
2912 if (empty($datas[
'picto'])) {
2913 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"ThirdParty").
'</u>';
2915 if (isset($this->
status)) {
2916 $datas[
'status'] =
' '.$this->getLibStatut(5);
2918 if (isset($this->client) && isset($this->fournisseur)) {
2919 $datas[
'type'] =
' ' . $this->
getTypeUrl(1,
'', 0,
'span');
2922 if (!empty($this->name_alias) && empty($noaliasinname)) {
2925 if (!empty($this->
email)) {
2926 $datas[
'email'] =
'<br>'.img_picto(
'',
'email',
'class="pictofixedwidth"').$this->email;
2928 if (!empty($this->url)) {
2929 $datas[
'url'] =
'<br>'.img_picto(
'',
'globe',
'class="pictofixedwidth"').$this->url;
2931 if (!empty($this->phone) || !empty($this->phone_mobile) || !empty($this->fax)) {
2932 $phonelist = array();
2934 $phonelist[] =
dol_print_phone($this->phone, $this->country_code, $this->
id, 0,
'',
' ',
'phone');
2937 if ($this->phone_mobile) {
2938 $phonelist[] =
dol_print_phone($this->phone_mobile, $this->country_code, $this->
id, 0,
'',
' ',
'phone_mobile');
2941 $phonelist[] =
dol_print_phone($this->fax, $this->country_code, $this->
id, 0,
'',
' ',
'fax');
2943 $datas[
'phonelist'] =
'<br>'.implode(
' ', $phonelist);
2947 $datas[
'address'] =
'<br><b>'.$langs->trans(
"Address").
':</b> '.
dol_format_address($this, 1,
', ', $langs);
2948 } elseif (!empty($this->country_code)) {
2949 $datas[
'address'] =
'<br><b>'.$langs->trans(
'Country').
':</b> '.$this->country_code;
2951 if (!empty($this->tva_intra) || (
getDolGlobalString(
'SOCIETE_SHOW_FIELD_IN_TOOLTIP') && strpos(
$conf->global->SOCIETE_SHOW_FIELD_IN_TOOLTIP,
'vatnumber') !==
false)) {
2952 $datas[
'vatintra'] =
'<br><b>'.$langs->trans(
'VATIntra').
':</b> '.
dol_escape_htmltag($this->tva_intra);
2956 if (strpos(
$conf->global->SOCIETE_SHOW_FIELD_IN_TOOLTIP,
'profid1') !==
false && $langs->trans(
'ProfId1'.$this->country_code) !=
'-') {
2957 $datas[
'profid1'] =
'<br><b>'.$langs->trans(
'ProfId1'.$this->country_code).
':</b> '.$this->idprof1;
2959 if (strpos(
$conf->global->SOCIETE_SHOW_FIELD_IN_TOOLTIP,
'profid2') !==
false && $langs->trans(
'ProfId2'.$this->country_code) !=
'-') {
2960 $datas[
'profid2'] =
'<br><b>'.$langs->trans(
'ProfId2'.$this->country_code).
':</b> '.$this->idprof2;
2962 if (strpos(
$conf->global->SOCIETE_SHOW_FIELD_IN_TOOLTIP,
'profid3') !==
false && $langs->trans(
'ProfId3'.$this->country_code) !=
'-') {
2963 $datas[
'profid3'] =
'<br><b>'.$langs->trans(
'ProfId3'.$this->country_code).
':</b> '.$this->idprof3;
2965 if (strpos(
$conf->global->SOCIETE_SHOW_FIELD_IN_TOOLTIP,
'profid4') !==
false && $langs->trans(
'ProfId4'.$this->country_code) !=
'-') {
2966 $datas[
'profid4'] =
'<br><b>'.$langs->trans(
'ProfId4'.$this->country_code).
':</b> '.$this->idprof4;
2968 if (strpos(
$conf->global->SOCIETE_SHOW_FIELD_IN_TOOLTIP,
'profid5') !==
false && $langs->trans(
'ProfId5'.$this->country_code) !=
'-') {
2969 $datas[
'profid5'] =
'<br><b>'.$langs->trans(
'ProfId5'.$this->country_code).
':</b> '.$this->idprof5;
2971 if (strpos(
$conf->global->SOCIETE_SHOW_FIELD_IN_TOOLTIP,
'profid6') !==
false && $langs->trans(
'ProfId6'.$this->country_code) !=
'-') {
2972 $datas[
'profid6'] =
'<br><b>'.$langs->trans(
'ProfId6'.$this->country_code).
':</b> '.$this->idprof6;
2976 $datas[
'separator'] =
'<br>';
2978 if (!empty($this->code_client) && ($this->client == 1 || $this->client == 3)) {
2979 $datas[
'customercode'] =
'<br><b>'.$langs->trans(
'CustomerCode').
':</b> '.$this->code_client;
2981 if (isModEnabled(
'accounting') && ($this->client == 1 || $this->client == 3)) {
2982 $langs->load(
'compta');
2983 $datas[
'accountancycustomercode'] =
'<br><b>'.$langs->trans(
'CustomerAccountancyCode').
':</b> '.$this->code_compta_client;
2986 if (!$nofetch && isModEnabled(
'category') && $this->client) {
2987 require_once DOL_DOCUMENT_ROOT .
'/categories/class/categorie.class.php';
2988 $form =
new Form($this->db);
2989 $datas[
'categories_customer'] =
'<br>' . $form->showCategories($this->
id, Categorie::TYPE_CUSTOMER, 1, 1);
2991 if (!empty($this->code_fournisseur) && $this->fournisseur) {
2992 $datas[
'suppliercode'] =
'<br><b>'.$langs->trans(
'SupplierCode').
':</b> '.$this->code_fournisseur;
2994 if (isModEnabled(
'accounting') && $this->fournisseur) {
2995 $langs->load(
'compta');
2996 $datas[
'accountancysuppliercode'] =
'<br><b>'.$langs->trans(
'SupplierAccountancyCode').
':</b> '.$this->code_compta_fournisseur;
2999 if (!$nofetch && isModEnabled(
'category') && $this->fournisseur) {
3000 require_once DOL_DOCUMENT_ROOT .
'/categories/class/categorie.class.php';
3001 $form =
new Form($this->db);
3002 $datas[
'categories_supplier'] =
'<br>' . $form->showCategories($this->
id, Categorie::TYPE_SUPPLIER, 1, 1);
3005 $datas[
'divclose'] =
'</div>';
3023 public function getNomUrl($withpicto = 0, $option =
'', $maxlen = 0, $notooltip = 0, $save_lastsearch_value = -1, $noaliasinname = 0, $target =
'', $morecss =
'')
3025 global
$conf, $langs, $hookmanager, $user;
3027 if (!empty(
$conf->dol_no_mouse_hover)) {
3031 $name = $this->
name ? $this->
name : $this->nom;
3033 if (
getDolGlobalString(
'SOCIETE_ON_SEARCH_AND_LIST_GO_ON_CUSTOMER_OR_SUPPLIER_CARD')) {
3034 if (empty($option) && $this->client > 0) {
3035 $option =
'customer';
3037 if (empty($option) && $this->fournisseur > 0) {
3038 $option =
'supplier';
3044 if (($this->client) && (!empty($this->code_client)) && (
getDolGlobalInt(
'SOCIETE_ADD_REF_IN_LIST') == 1 ||
getDolGlobalInt(
'SOCIETE_ADD_REF_IN_LIST') == 2)) {
3045 $code = $this->code_client.
' - ';
3048 if (($this->fournisseur) && (!empty($this->code_fournisseur)) && (
getDolGlobalInt(
'SOCIETE_ADD_REF_IN_LIST') == 1 ||
getDolGlobalInt(
'SOCIETE_ADD_REF_IN_LIST') == 3)) {
3049 $code .= $this->code_fournisseur.
' - ';
3054 $name = $code.
' '.$name;
3061 if (!empty($this->name_alias) && empty($noaliasinname)) {
3062 $name .=
' ('.$this->name_alias.
')';
3068 'objecttype' => $this->element,
3069 'option' => $option,
3072 $classfortooltip =
'classfortooltip';
3075 $classfortooltip =
'classforajaxtooltip';
3076 $dataparams =
' data-params="'.dol_escape_htmltag(json_encode($params)).
'"';
3085 if ($option ==
'customer' || $option ==
'compta' || $option ==
'category') {
3086 $linkstart =
'<a href="'.DOL_URL_ROOT.
'/comm/card.php?socid='.$this->id;
3087 } elseif ($option ==
'prospect' && !
getDolGlobalString(
'SOCIETE_DISABLE_PROSPECTS')) {
3088 $linkstart =
'<a href="'.DOL_URL_ROOT.
'/comm/card.php?socid='.$this->id;
3089 } elseif ($option ==
'supplier' || $option ==
'category_supplier') {
3090 $linkstart =
'<a href="'.DOL_URL_ROOT.
'/fourn/card.php?socid='.$this->id;
3091 } elseif ($option ==
'agenda') {
3092 $linkstart =
'<a href="'.DOL_URL_ROOT.
'/societe/agenda.php?socid='.$this->id;
3093 } elseif ($option ==
'project') {
3094 $linkstart =
'<a href="'.DOL_URL_ROOT.
'/societe/project.php?socid='.$this->id;
3095 } elseif ($option ==
'margin') {
3096 $linkstart =
'<a href="'.DOL_URL_ROOT.
'/margin/tabs/thirdpartyMargins.php?socid='.$this->
id.
'&type=1';
3097 } elseif ($option ==
'contact') {
3098 $linkstart =
'<a href="'.DOL_URL_ROOT.
'/societe/contact.php?socid='.$this->id;
3099 } elseif ($option ==
'ban') {
3100 $linkstart =
'<a href="'.DOL_URL_ROOT.
'/societe/paymentmodes.php?socid='.$this->id;
3104 if (empty($linkstart)) {
3105 $linkstart =
'<a href="'.DOL_URL_ROOT.
'/societe/card.php?socid='.$this->id;
3109 $linkstart .= (!empty($this->canvas) ?
'&canvas='.$this->canvas :
'');
3111 $add_save_lastsearch_values = ($save_lastsearch_value == 1 ? 1 : 0);
3112 if ($save_lastsearch_value == -1 && isset($_SERVER[
"PHP_SELF"]) && preg_match(
'/list\.php/', $_SERVER[
"PHP_SELF"])) {
3113 $add_save_lastsearch_values = 1;
3115 if ($add_save_lastsearch_values) {
3116 $linkstart .=
'&save_lastsearch_values=1';
3121 if (empty($notooltip)) {
3123 $label = $langs->trans(
"ShowCompany");
3124 $linkclose .=
' alt="'.dolPrintHTMLForAttribute($label).
'"';
3126 $linkclose .= ($label ?
' title="'.dolPrintHTMLForAttribute($label).
'"' :
' title="tocomplete"');
3127 $linkclose .= $dataparams.
' class="'.$classfortooltip.($morecss ?
' '.$morecss :
'').
' refurl valignmiddle"';
3128 $target_value = array(
'_self',
'_blank',
'_parent',
'_top');
3129 if (in_array($target, $target_value)) {
3130 $linkclose .=
' target="'.dol_escape_htmltag($target).
'"';
3133 $linkclose .=
' class="valignmiddle'.($morecss ?
' '.$morecss :
'').
'"';
3135 $linkstart .= $linkclose.
'>';
3138 if (!$user->hasRight(
'societe',
'client',
'voir') && $user->socid > 0 && $this->id != $user->socid) {
3143 $result .= $linkstart;
3145 $result .=
img_object(($notooltip ?
'' : $label), ($this->picto ? $this->picto :
'generic'), (
' class="'.(($withpicto != 2) ?
'paddingright' :
'').
'"'), 0, 0, $notooltip ? 0 : 1);
3147 if ($withpicto != 2) {
3150 $result .= $linkend;
3153 $hookmanager->initHooks(array(
'thirdpartydao'));
3154 $parameters = array(
3156 'getnomurl' => &$result,
3157 'withpicto ' => $withpicto,
3158 'option' => $option,
3159 'maxlen' => $maxlen,
3160 'notooltip' => $notooltip,
3161 'save_lastsearch_value' => $save_lastsearch_value
3163 $reshook = $hookmanager->executeHooks(
'getNomUrl', $parameters, $this, $action);
3165 $result = $hookmanager->resPrint;
3167 $result .= $hookmanager->resPrint;
3182 public function getTypeUrl($withpicto = 0, $option =
'', $notooltip = 0, $tag =
'a')
3187 if (empty($option) || preg_match(
'/prospect/', $option)) {
3188 if (($this->client == 2 || $this->client == 3) && !
getDolGlobalString(
'SOCIETE_DISABLE_PROSPECTS')) {
3189 $s .=
'<'.$tag.
' class="customer-back opacitymedium" title="'.
dolPrintHTMLForAttribute($langs->trans(
"Prospect")).
'"';
3190 $s .= $tag ==
'a' ?
' href="'.DOL_URL_ROOT.
'/comm/card.php?socid='.$this->
id.
'"' :
'';
3191 $s .=
'>'.dol_substr($langs->trans(
"Prospect"), 0, 1).
'</'.$tag.
'>';
3194 if (empty($option) || preg_match(
'/customer/', $option)) {
3195 if (($this->client == 1 || $this->client == 3) && !
getDolGlobalString(
'SOCIETE_DISABLE_CUSTOMERS')) {
3197 $s.= $tag ==
'a' ?
' href="'.DOL_URL_ROOT.
'/comm/card.php?socid='.$this->
id.
'"' :
'';
3198 $s .=
'>'.dol_substr($langs->trans(
"Customer"), 0, 1).
'</'.$tag.
'>';
3201 if (empty($option) || preg_match(
'/supplier/', $option)) {
3202 if ((isModEnabled(
"supplier_order") || isModEnabled(
"supplier_invoice")) && $this->fournisseur) {
3204 $s .= $tag ==
'a' ?
' href="'.DOL_URL_ROOT.
'/fourn/card.php?socid='.$this->
id.
'"' :
'';
3205 $s .=
'>'.dol_substr($langs->trans(
"Supplier"), 0, 1).
'</'.$tag.
'>';
3236 $langs->load(
'companies');
3238 $statusType =
'status4';
3240 $statusType =
'status6';
3243 if (empty($this->labelStatus) || empty($this->labelStatusShort)) {
3244 $this->labelStatus[0] = $langs->transnoentitiesnoconv(
"ActivityCeased");
3245 $this->labelStatus[1] = $langs->transnoentitiesnoconv(
"InActivity");
3246 $this->labelStatusShort[0] = $langs->transnoentitiesnoconv(
"ActivityCeased");
3247 $this->labelStatusShort[1] = $langs->transnoentitiesnoconv(
"InActivity");
3250 return dolGetStatus($this->labelStatus[$status], $this->labelStatusShort[$status],
'', $statusType, $mode);
3267 if ($this->
email && $addthirdparty) {
3268 if (empty($this->
name)) {
3269 $this->
name = $this->nom;
3271 $contact_emails[
'thirdparty'] = ($addthirdparty == 2 ?
'<span class="opacitymedium">' :
'').$langs->transnoentitiesnoconv(
"ThirdParty").($addthirdparty == 2 ?
'</span>' :
'').
': '.
dol_trunc($this->
name, 16).
" <".$this->
email.
">";
3275 return $contact_emails;
3291 if (!empty($this->phone)) {
3292 if (empty($this->
name)) {
3293 $this->
name = $this->nom;
3296 $contact_phone[
'thirdparty'] = $langs->transnoentitiesnoconv(
"ThirdParty").
': '.
dol_trunc($this->
name, 16).
" <".$this->phone.
">";
3298 return $contact_phone;
3314 $contact_property = array();
3317 $sql =
"SELECT rowid, email, statut as status, phone_mobile, lastname, poste, firstname";
3318 $sql .=
" FROM ".MAIN_DB_PREFIX.
"socpeople";
3319 $sql .=
" WHERE fk_soc = ".((int) $this->
id);
3320 $sql .=
" AND entity IN (".getEntity($this->element).
")";
3321 $sql .=
" ORDER BY lastname, firstname";
3323 $resql = $this->db->query($sql);
3325 $nump = $this->db->num_rows($resql);
3329 if ($mode ==
'email') {
3335 while ($i < $nump) {
3336 $obj = $this->db->fetch_object($resql);
3337 if ($mode ==
'email') {
3338 $property = $obj->email;
3339 } elseif ($mode ==
'mobile') {
3340 $property = $obj->phone_mobile;
3342 $property = $obj->$mode;
3346 if ($obj->status == 1 || empty($hidedisabled)) {
3347 if (empty($property)) {
3348 if ($mode ==
'email') {
3349 $property = $langs->transnoentitiesnoconv(
"NoEMail");
3350 } elseif ($mode ==
'mobile') {
3351 $property = $langs->transnoentitiesnoconv(
"NoMobilePhone");
3355 if (!empty($obj->poste)) {
3356 $contact_property[$obj->rowid] = trim(
dolGetFirstLastname($obj->firstname, $obj->lastname)).($obj->poste ?
" - ".$obj->poste :
"").(($mode !=
'poste' && $property) ?
" ".$sepa.$property.$sepb :
'');
3358 $contact_property[$obj->rowid] = trim(
dolGetFirstLastname($obj->firstname, $obj->lastname)).(($mode !=
'poste' && $property) ?
" ".$sepa.$property.$sepb :
'');
3367 return $contact_property;
3380 $contacts = array();
3382 $sql =
"SELECT rowid, lastname, firstname FROM ".MAIN_DB_PREFIX.
"socpeople WHERE fk_soc = ".((int) $this->
id);
3383 $resql = $this->db->query($sql);
3385 $nump = $this->db->num_rows($resql);
3388 while ($i < $nump) {
3389 $obj = $this->db->fetch_object($resql);
3409 require_once DOL_DOCUMENT_ROOT.
'/contact/class/contact.class.php';
3410 $contacts = array();
3412 $sql =
"SELECT rowid FROM ".MAIN_DB_PREFIX.
"socpeople WHERE fk_soc = ".((int) $this->
id);
3413 $resql = $this->db->query($sql);
3415 $nump = $this->db->num_rows($resql);
3418 while ($i < $nump) {
3419 $obj = $this->db->fetch_object($resql);
3420 $contact =
new Contact($this->db);
3421 $contact->fetch($obj->rowid);
3422 $contacts[] = $contact;
3443 $contact_property =
'';
3445 if (empty($rowid)) {
3449 $sql =
"SELECT rowid, email, phone_mobile, lastname, firstname";
3450 $sql .=
" FROM ".MAIN_DB_PREFIX.
"socpeople";
3451 $sql .=
" WHERE rowid = ".((int) $rowid);
3453 $resql = $this->db->query($sql);
3455 $nump = $this->db->num_rows($resql);
3458 $obj = $this->db->fetch_object($resql);
3460 if ($mode ==
'email') {
3462 } elseif ($mode ==
'mobile') {
3463 $contact_property = $obj->phone_mobile;
3466 return $contact_property;
3485 require_once DOL_DOCUMENT_ROOT.
'/societe/class/companybankaccount.class.php';
3489 $bac->fetch(0,
'', $this->
id);
3492 if ($mode ==
'label') {
3493 return $bac->getRibLabel(
true);
3494 } elseif ($mode ==
'rum') {
3495 if (empty($bac->rum)) {
3496 require_once DOL_DOCUMENT_ROOT.
'/compta/prelevement/class/bonprelevement.class.php';
3498 $bac->fetch_thirdparty();
3499 $bac->rum = $prelevement->buildRumNumber($bac->thirdparty->code_client, $bac->datec, $bac->id);
3502 } elseif ($mode ==
'format') {
3503 return $bac->frstrecur;
3505 return 'BadParameterToFunctionDisplayRib';
3521 require_once DOL_DOCUMENT_ROOT.
'/societe/class/companybankaccount.class.php';
3522 $sql =
"SELECT rowid FROM ".MAIN_DB_PREFIX.
"societe_rib WHERE type = 'ban' AND fk_soc = ".((int) $this->
id);
3523 $result = $this->db->query($sql);
3525 $this->error = $this->db->lasterror();
3526 $this->errors[] = $this->db->lasterror();
3529 $num_rows = $this->db->num_rows($result);
3530 $rib_array = array();
3532 while ($obj = $this->db->fetch_object($result)) {
3534 $rib->fetch($obj->rowid);
3535 $rib_array[] = $rib;
3548 require_once DOL_DOCUMENT_ROOT.
'/societe/class/companybankaccount.class.php';
3549 $sql =
"SELECT rowid FROM ".MAIN_DB_PREFIX.
"societe_rib WHERE type = 'ban' AND default_rib = 1 AND fk_soc = ". (int) $this->
id;
3550 $resql = $this->db->query($sql);
3552 $this->error = $this->db->lasterror();
3553 $this->errors[] = $this->db->lasterror();
3556 $num_rows = $this->db->num_rows($resql);
3557 $rib_array = array();
3559 while ($obj = $this->db->fetch_object($resql)) {
3577 public function get_codeclient($objsoc =
null, $type = 0)
3584 $dirsociete = array_merge(array(
'/core/modules/societe/'),
$conf->modules_parts[
'societe']);
3585 foreach ($dirsociete as $dirroot) {
3592 $mod =
new $module($this->db);
3593 '@phan-var-force ModeleThirdPartyCode $mod';
3595 $this->code_client = $mod->getNextValue($objsoc, $type);
3596 $this->prefixCustomerIsRequired = $mod->prefixIsRequired;
3598 dol_syslog(get_class($this).
"::get_codeclient code_client=".$this->code_client.
" module=".$module);
3611 public function get_codefournisseur($objsoc =
null, $type = 1)
3618 $dirsociete = array_merge(array(
'/core/modules/societe/'),
$conf->modules_parts[
'societe']);
3619 foreach ($dirsociete as $dirroot) {
3626 $mod =
new $module($this->db);
3627 '@phan-var-force ModeleThirdPartyCode $mod';
3629 $this->code_fournisseur = $mod->getNextValue($objsoc, $type);
3631 dol_syslog(get_class($this).
"::get_codefournisseur code_fournisseur=".$this->code_fournisseur.
" module=".$module);
3649 $dirsociete = array_merge(array(
'/core/modules/societe/'),
$conf->modules_parts[
'societe']);
3650 foreach ($dirsociete as $dirroot) {
3657 $mod =
new $module($this->db);
3658 '@phan-var-force ModeleThirdPartyCode $mod';
3660 dol_syslog(get_class($this).
"::codeclient_modifiable code_client=".$this->code_client.
" module=".$module);
3661 if ($mod->code_modifiable_null && !$this->code_client) {
3664 if ($mod->code_modifiable_invalide && $this->check_codeclient() < 0) {
3667 if ($mod->code_modifiable) {
3690 $dirsociete = array_merge(array(
'/core/modules/societe/'),
$conf->modules_parts[
'societe']);
3691 foreach ($dirsociete as $dirroot) {
3698 $mod =
new $module($this->db);
3699 '@phan-var-force ModeleThirdPartyCode $mod';
3701 dol_syslog(get_class($this).
"::codefournisseur_modifiable code_founisseur=".$this->code_fournisseur.
" module=".$module);
3702 if ($mod->code_modifiable_null && !$this->code_fournisseur) {
3705 if ($mod->code_modifiable_invalide && $this->check_codefournisseur() < 0) {
3708 if ($mod->code_modifiable) {
3737 $dirsociete = array_merge(array(
'/core/modules/societe/'),
$conf->modules_parts[
'societe']);
3738 foreach ($dirsociete as $dirroot) {
3745 $mod =
new $module($this->db);
3746 '@phan-var-force ModeleThirdPartyCode $mod';
3748 dol_syslog(get_class($this).
"::check_codeclient code_client=".$this->code_client.
" module=".$module);
3749 $result = $mod->verif($this->db, $this->code_client, $this, 0);
3751 $this->error = $mod->error;
3752 $this->errors = $mod->errors;
3779 $dirsociete = array_merge(array(
'/core/modules/societe/'),
$conf->modules_parts[
'societe']);
3780 foreach ($dirsociete as $dirroot) {
3787 $mod =
new $module($this->db);
3788 '@phan-var-force ModeleThirdPartyCode $mod';
3790 dol_syslog(get_class($this).
"::check_codefournisseur code_fournisseur=".$this->code_fournisseur.
" module=".$module);
3791 $result = $mod->verif($this->db, $this->code_fournisseur, $this, 1);
3793 $this->error = $mod->error;
3794 $this->errors = $mod->errors;
3819 $dirsociete = array_merge(array(
'/core/modules/societe/'),
$conf->modules_parts[
'societe']);
3820 foreach ($dirsociete as $dirroot) {
3828 $mod =
new $module();
3829 '@phan-var-force ModeleAccountancyCode $mod';
3832 $result = $mod->get_code($this->db, $this, $type);
3834 if ($type ==
'customer') {
3835 $this->code_compta_client = $mod->code;
3836 } elseif ($type ==
'supplier') {
3837 $this->code_compta_fournisseur = $mod->code;
3842 $this->error =
'ErrorAccountancyCodeNotDefined';
3846 if ($type ==
'customer') {
3847 $this->code_compta_client =
'';
3848 } elseif ($type ==
'supplier') {
3849 $this->code_compta_fournisseur =
'';
3864 dol_syslog(get_class($this).
'::setParent', LOG_DEBUG);
3870 if ($sameparent < 0) {
3873 if ($sameparent == 1) {
3874 setEventMessages(
'ParentCompanyToAddIsAlreadyAChildOfModifiedCompany',
null,
'warnings');
3879 $sql =
'UPDATE '.MAIN_DB_PREFIX.
'societe SET parent = '.($id > 0 ? $id :
'null').
' WHERE rowid = '.((
int) $this->id);
3881 $resql = $this->db->query($sql);
3883 $this->parent = $id;
3903 if ($counter > 100) {
3904 dol_syslog(
"Too high level of parent - child for company. May be an infinite loop ?", LOG_WARNING);
3907 $sql =
'SELECT s.parent';
3908 $sql .=
' FROM '.MAIN_DB_PREFIX.
'societe as s';
3909 $sql .=
' WHERE rowid = '.((int) $idparent);
3910 $resql = $this->db->query($sql);
3912 $obj = $this->db->fetch_object($resql);
3914 if ($obj->parent ==
'') {
3916 } elseif ($obj->parent == $idchild) {
3938 if ($company_id > 0) {
3939 $sql =
"SELECT parent FROM " . MAIN_DB_PREFIX .
"societe WHERE rowid = ".((int) $company_id);
3940 $resql = $this->db->query($sql);
3942 if ($obj = $this->db->fetch_object($resql)) {
3943 $parent = $obj->parent;
3944 if ($parent > 0 && !in_array($parent, $parents)) {
3945 $parents[] = $parent;
3951 $this->db->free($resql);
3953 setEventMessage($langs->trans(
'GetCompanyParentsError', $this->db->lasterror()),
'errors');
4038 $sql =
"SELECT COUNT(*) as nb FROM ".MAIN_DB_PREFIX.
"societe WHERE ".$field.
" = '".$this->db->escape($value).
"' AND entity IN (".
getEntity(
'societe').
")";
4040 $sql .=
" AND rowid <> ".$socid;
4042 $resql = $this->db->query($sql);
4044 $obj = $this->db->fetch_object($resql);
4048 print $this->db->error();
4050 $this->db->free($resql);
4074 require_once DOL_DOCUMENT_ROOT.
'/core/lib/profid.lib.php';
4083 if ($idprof == 1 && $soc->country_code ==
'FR' && !
isValidSiren($this->idprof1)) {
4088 if ($idprof == 2 && $soc->country_code ==
'FR' && !
isValidSiret($this->idprof2)) {
4093 if ($idprof == 1 && $soc->country_code ==
'ES') {
4098 if ($idprof == 1 && $soc->country_code ==
'PT' && !
isValidTinForPT($this->idprof1)) {
4103 if ($idprof == 1 && $soc->country_code ==
'DZ' && !
isValidTinForDZ($this->idprof1)) {
4108 if ($idprof == 1 && $soc->country_code ==
'BE' && !
isValidTinForBE($this->idprof1)) {
4127 global
$conf, $langs, $hookmanager;
4132 $hookmanager->initHooks(array(
'idprofurl'));
4133 $parameters = array(
'idprof' => $idprof,
'company' => $thirdparty);
4134 $reshook = $hookmanager->executeHooks(
'getIdProfUrl', $parameters, $this, $action);
4135 if (empty($reshook)) {
4141 $strippedIdProf1 = str_replace(
' ',
'', $thirdparty->idprof1);
4142 if ($idprof == 1 && $thirdparty->country_code ==
'FR') {
4143 $url =
'https://annuaire-entreprises.data.gouv.fr/entreprise/'.$strippedIdProf1;
4145 if ($idprof == 1 && ($thirdparty->country_code ==
'GB' || $thirdparty->country_code ==
'UK')) {
4146 $url =
'https://beta.companieshouse.gov.uk/company/'.$strippedIdProf1;
4148 if ($idprof == 1 && $thirdparty->country_code ==
'ES') {
4149 $url =
'http://www.e-informa.es/servlet/app/portal/ENTP/screen/SProducto/prod/ETIQUETA_EMPRESA/nif/'.$strippedIdProf1;
4151 if ($idprof == 1 && $thirdparty->country_code ==
'IN') {
4152 $url =
'http://www.tinxsys.com/TinxsysInternetWeb/dealerControllerServlet?tinNumber='.$strippedIdProf1.
';&searchBy=TIN&backPage=searchByTin_Inter.jsp';
4154 if ($idprof == 1 && $thirdparty->country_code ==
'DZ') {
4155 $url =
'http://nif.mfdgi.gov.dz/nif.asp?Nif='.$strippedIdProf1;
4157 if ($idprof == 1 && $thirdparty->country_code ==
'PT') {
4158 $url =
'http://www.nif.pt/'.$strippedIdProf1;
4162 return '<a target="_blank" rel="noopener noreferrer" href="'.$url.
'">'.$langs->trans(
"Check").
'</a>';
4165 return $hookmanager->resPrint;
4180 $sql =
"SELECT COUNT(*) as numproj FROM ".MAIN_DB_PREFIX.
"projet WHERE fk_soc = ".((int) $this->
id);
4181 $resql = $this->db->query($sql);
4183 $obj = $this->db->fetch_object($resql);
4184 $count = $obj->numproj;
4187 print $this->db->error();
4189 $this->db->free($resql);
4190 return ($count > 0);
4202 $sql =
"SELECT s.rowid, s.nom as name, s.datec, tms as datem,";
4203 $sql .=
" fk_user_creat, fk_user_modif";
4204 $sql .=
" FROM ".MAIN_DB_PREFIX.
"societe as s";
4205 $sql .=
" WHERE s.rowid = ".((int) $id);
4207 $result = $this->db->query($sql);
4209 if ($this->db->num_rows($result)) {
4210 $obj = $this->db->fetch_object($result);
4212 $this->
id = $obj->rowid;
4214 $this->user_creation_id = $obj->fk_user_creat;
4215 $this->user_modification_id = $obj->fk_user_modif;
4216 $this->date_creation = $this->db->jdate($obj->datec);
4217 $this->date_modification = empty($obj->datem) ?
'' : $this->db->jdate($obj->datem);
4219 $this->
ref = $obj->name;
4222 $this->db->free($result);
4236 $isACompany =
getDolGlobalInt(
'MAIN_UNKNOWN_CUSTOMERS_ARE_COMPANIES', 1);
4239 if (!empty($this->tva_intra)) {
4241 } elseif (!empty($this->idprof1) || !empty($this->idprof2) || !empty($this->idprof3) || !empty($this->idprof4) || !empty($this->idprof5) || !empty($this->idprof6)) {
4245 if (preg_match(
'/^TE_PRIVATE/', $this->typent_code)) {
4253 return (
bool) $isACompany;
4263 require_once DOL_DOCUMENT_ROOT.
'/core/lib/company.lib.php';
4276 $this->SupplierCategories = array();
4277 $sql =
"SELECT rowid, label";
4278 $sql .=
" FROM ".MAIN_DB_PREFIX.
"categorie";
4279 $sql .=
" WHERE type = ".Categorie::TYPE_SUPPLIER;
4281 $resql = $this->db->query($sql);
4283 while ($obj = $this->db->fetch_object($resql)) {
4284 $this->SupplierCategories[$obj->rowid] = $obj->label;
4302 if ($categorie_id > 0 && $this->
id > 0) {
4303 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"categorie_fournisseur (fk_categorie, fk_soc) ";
4304 $sql .=
" VALUES (".((int) $categorie_id).
", ".((int) $this->
id).
")";
4306 if ($resql = $this->db->query($sql)) {
4322 $sql =
"SELECT count(mc.email) as nb";
4323 $sql .=
" FROM ".MAIN_DB_PREFIX.
"mailing_cibles as mc, ".MAIN_DB_PREFIX.
"mailing as m";
4324 $sql .=
" WHERE mc.fk_mailing=m.rowid AND mc.email = '".$this->db->escape($this->
email).
"' ";
4325 $sql .=
" AND m.entity IN (".getEntity($this->element).
") AND mc.statut NOT IN (-1,0)";
4327 $resql = $this->db->query($sql);
4329 $obj = $this->db->fetch_object($resql);
4332 $this->db->free($resql);
4335 $this->error = $this->db->error();
4355 $sql =
"SELECT COUNT(rowid) as nb FROM ".MAIN_DB_PREFIX.
"mailing_unsubscribe WHERE entity IN (".
getEntity(
'mailing', 0).
") AND email = '".$this->db->escape($this->
email).
"'";
4356 $resql = $this->db->query($sql);
4358 $obj = $this->db->fetch_object($resql);
4359 $noemail = $obj->nb;
4360 if (empty($noemail)) {
4361 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"mailing_unsubscribe(email, entity, date_creat) VALUES ('".$this->db->escape($this->
email).
"', ".
getEntity(
'mailing', 0).
", '".$this->db->idate(
dol_now()).
"')";
4362 $resql = $this->db->query($sql);
4365 $this->error = $this->db->lasterror();
4366 $this->errors[] = $this->error;
4371 $this->error = $this->db->lasterror();
4372 $this->errors[] = $this->error;
4375 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"mailing_unsubscribe WHERE email = '".$this->db->escape($this->
email).
"' AND entity IN (".
getEntity(
'mailing', 0).
")";
4376 $resql = $this->db->query($sql);
4379 $this->error = $this->db->lasterror();
4380 $this->errors[] = $this->error;
4384 if (empty($error)) {
4385 $this->no_email = $no_email;
4386 $this->db->commit();
4389 $this->db->rollback();
4406 $sql =
"SELECT COUNT(rowid) as nb FROM ".MAIN_DB_PREFIX.
"mailing_unsubscribe WHERE entity IN (".
getEntity(
'mailing').
") AND email = '".$this->db->escape($this->
email).
"'";
4407 $resql = $this->db->query($sql);
4409 $obj = $this->db->fetch_object($resql);
4410 $this->no_email = $obj->nb;
4413 $this->error = $this->db->lasterror();
4414 $this->errors[] = $this->error;
4434 global
$conf, $user, $langs;
4436 dol_syslog(get_class($this).
"::create_from_member", LOG_DEBUG);
4437 $fullname = $member->getFullName($langs);
4439 if ($member->morphy ==
'mor') {
4440 if (empty($socname)) {
4441 $socname = $member->company ? $member->company : $member->societe;
4443 if (!empty($fullname) && empty($socalias)) {
4444 $socalias = $fullname;
4446 } elseif (empty($socname) && $member->morphy ==
'phy') {
4447 if (empty($socname)) {
4448 $socname = $fullname;
4450 if (!empty($member->company) && empty($socalias)) {
4451 $socalias = $member->company;
4456 $alias = $socalias ? $socalias :
'';
4460 $this->
name = $name;
4461 $this->name_alias = $alias;
4462 $this->
address = $member->address;
4463 $this->zip = $member->zip;
4464 $this->town = $member->town;
4465 $this->country_code = $member->country_code;
4466 $this->country_id = $member->country_id;
4467 $this->phone = $member->phone;
4468 $this->
email = $member->email;
4469 $this->socialnetworks = $member->socialnetworks;
4470 $this->entity = $member->entity;
4473 $this->code_client = ($customercode ? $customercode : -1);
4474 $this->code_fournisseur =
'-1';
4475 $this->typent_code = ($member->morphy ==
'phy' ?
'TE_PRIVATE' : 0);
4476 $this->typent_id = $this->typent_code ?
dol_getIdFromCode($this->db, $this->typent_code,
'c_typent',
'id',
'code') : 0;
4481 $result = $this->
create($user);
4487 $this->name_bis = $member->lastname;
4488 $this->firstname = $member->firstname;
4489 $this->civility_id = $member->civility_id;
4491 dol_syslog(
"We ask to create a contact/address too", LOG_DEBUG);
4496 $this->db->rollback();
4501 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"adherent";
4502 $sql .=
" SET fk_soc = ".((int) $this->
id);
4503 $sql .=
" WHERE rowid = ".((int) $member->id);
4505 $resql = $this->db->query($sql);
4507 $this->db->commit();
4510 $this->error = $this->db->error();
4512 $this->db->rollback();
4517 dol_syslog(get_class($this).
"::create_from_member - 2 - ".$this->error.
" - ".implode(
',', $this->errors), LOG_ERR);
4519 $this->db->rollback();
4535 $this->entity =
$conf->entity;
4537 $this->nom = $this->name;
4549 $country_code = $country_label =
'';
4552 $country_id = (is_numeric($tmp[0])) ? (
int) $tmp[0] : 0;
4553 if (!empty($tmp[1])) {
4554 $country_code = $tmp[1];
4555 $country_label = $tmp[2];
4558 dol_syslog(
"Your country setup use an old syntax. Reedit it using setup area.", LOG_WARNING);
4559 include_once DOL_DOCUMENT_ROOT.
'/core/lib/company.lib.php';
4560 $country_code =
getCountry($country_id,
'2', $this->db);
4561 $country_label =
getCountry($country_id,
'', $this->db);
4564 $this->country_id = $country_id;
4565 $this->country_code = $country_code;
4566 $this->country = $country_label;
4567 if (is_object($langs)) {
4568 $this->country = ($langs->trans(
'Country'.$country_code) !=
'Country'.$country_code) ? $langs->trans(
'Country'.$country_code) : $country_label;
4578 $state_id = (int) $tmp[0];
4579 if (!empty($tmp[1])) {
4580 $state_code = $tmp[1];
4581 $state_label = $tmp[2];
4583 dol_syslog(
"Your setup of State has an old syntax (entity=".
$conf->entity.
"). Go in Home - Setup - Organization then Save should remove this error.", LOG_ERR);
4584 include_once DOL_DOCUMENT_ROOT.
'/core/lib/company.lib.php';
4585 $state_code =
getState($state_id,
'2', $this->db);
4586 $state_label =
getState($state_id,
'0', $this->db);
4589 $this->state_id = $state_id;
4590 $this->state_code = $state_code;
4591 $this->state = $state_label;
4592 if (is_object($langs)) {
4593 $this->state = ($langs->trans(
'State'.$state_code) !=
'State'.$state_code) ? $langs->trans(
'State'.$state_code) : $state_label;
4608 $this->socialnetworks = array();
4609 if (!empty($facebook_url)) {
4610 $this->socialnetworks[
'facebook'] = $facebook_url;
4612 if (!empty($twitter_url)) {
4613 $this->socialnetworks[
'twitter'] = $twitter_url;
4615 if (!empty($linkedin_url)) {
4616 $this->socialnetworks[
'linkedin'] = $linkedin_url;
4618 if (!empty($instagram_url)) {
4619 $this->socialnetworks[
'instagram'] = $instagram_url;
4621 if (!empty($youtube_url)) {
4622 $this->socialnetworks[
'youtube'] = $youtube_url;
4624 if (!empty($github_url)) {
4625 $this->socialnetworks[
'github'] = $github_url;
4642 $this->forme_juridique_code =
getDolGlobalInt(
'MAIN_INFO_SOCIETE_FORME_JURIDIQUE');
4649 $this->logo_squarred_small =
getDolGlobalString(
'MAIN_INFO_SOCIETE_LOGO_SQUARRED_SMALL');
4650 $this->logo_squarred_mini =
getDolGlobalString(
'MAIN_INFO_SOCIETE_LOGO_SQUARRED_MINI');
4656 $this->localtax1_assuj = ((isset(
$conf->global->FACTURE_LOCAL_TAX1_OPTION) && (
getDolGlobalString(
'FACTURE_LOCAL_TAX1_OPTION') ==
'1' ||
getDolGlobalString(
'FACTURE_LOCAL_TAX1_OPTION') ==
'localtax1on')) ? 1 : 0);
4657 $this->localtax2_assuj = ((isset(
$conf->global->FACTURE_LOCAL_TAX2_OPTION) && (
getDolGlobalString(
'FACTURE_LOCAL_TAX2_OPTION') ==
'1' ||
getDolGlobalString(
'FACTURE_LOCAL_TAX2_OPTION') ==
'localtax2on')) ? 1 : 0);
4676 $this->
name =
'THIRDPARTY SPECIMEN '.dol_print_date($now,
'dayhourlog');
4677 $this->nom = $this->name;
4678 $this->ref_ext =
'Ref ext';
4679 $this->specimen = 1;
4680 $this->
address =
'21 jump street';
4681 $this->zip =
'99999';
4682 $this->town =
'MyTown';
4683 $this->state_id = 1;
4684 $this->state_code =
'AA';
4685 $this->state =
'MyState';
4686 $this->country_id = 1;
4687 $this->country_code =
'FR';
4688 $this->
email =
'specimen@specimen.com';
4689 $this->socialnetworks = array(
4690 'skype' =>
'skypepseudo',
4691 'twitter' =>
'twitterpseudo',
4692 'facebook' =>
'facebookpseudo',
4693 'linkedin' =>
'linkedinpseudo',
4695 $this->url =
'http://www.specimen.com';
4697 $this->phone =
'0909090901';
4698 $this->phone_mobile =
'0909090901';
4699 $this->fax =
'0909090909';
4701 $this->code_client =
'CC-'.dol_print_date($now,
'dayhourlog');
4702 $this->code_fournisseur =
'SC-'.dol_print_date($now,
'dayhourlog');
4703 $this->typent_code =
'TE_OTHER';
4704 $this->capital = 10000;
4706 $this->prospect = 1;
4707 $this->fournisseur = 1;
4708 $this->tva_assuj = 1;
4709 $this->tva_intra =
'EU1234567';
4710 $this->note_public =
'This is a comment (public)';
4711 $this->note_private =
'This is a comment (private)';
4713 $this->idprof1 =
'idprof1';
4714 $this->idprof2 =
'idprof2';
4715 $this->idprof3 =
'idprof3';
4716 $this->idprof4 =
'idprof4';
4717 $this->idprof5 =
'idprof5';
4718 $this->idprof6 =
'idprof6';
4731 $sql =
"SELECT t.localtax1, t.localtax2";
4732 $sql .=
" FROM ".MAIN_DB_PREFIX.
"c_tva as t, ".MAIN_DB_PREFIX.
"c_country as c";
4733 $sql .=
" WHERE t.fk_pays = c.rowid AND c.code = '".$this->db->escape($this->country_code).
"'";
4734 $sql .=
" AND t.active = 1";
4735 $sql .=
" AND t.entity IN (".getEntity(
'c_tva').
")";
4736 if (empty($localTaxNum)) {
4737 $sql .=
" AND (t.localtax1_type <> '0' OR t.localtax2_type <> '0')";
4738 } elseif ($localTaxNum == 1) {
4739 $sql .=
" AND t.localtax1_type <> '0'";
4740 } elseif ($localTaxNum == 2) {
4741 $sql .=
" AND t.localtax2_type <> '0'";
4744 $resql = $this->db->query($sql);
4746 return ($this->db->num_rows($resql) > 0);
4759 $sql =
"SELECT t.rowid";
4760 $sql .=
" FROM ".MAIN_DB_PREFIX.
"c_tva as t, ".MAIN_DB_PREFIX.
"c_country as c";
4761 $sql .=
" WHERE t.fk_pays = c.rowid AND c.code = '".$this->db->escape($this->country_code).
"'";
4762 $sql .=
" AND t.active = 1 AND t.recuperableonly = 1";
4763 $sql .=
" AND t.entity IN (".getEntity(
'c_tva').
")";
4766 $resql = $this->db->query($sql);
4768 return ($this->db->num_rows($resql) > 0);
4782 $sql =
"SELECT COUNT(*) as nb";
4783 $sql .=
" FROM ".MAIN_DB_PREFIX.
"c_revenuestamp as r, ".MAIN_DB_PREFIX.
"c_country as c";
4784 $sql .=
" WHERE r.fk_pays = c.rowid AND c.code = '".$this->db->escape($this->country_code).
"'";
4785 $sql .=
" AND r.active = 1";
4788 $resql = $this->db->query($sql);
4790 $obj = $this->db->fetch_object($resql);
4791 return ($obj->nb > 0);
4793 $this->error = $this->db->lasterror();
4821 if ($fk_prospectlevel !=
'') {
4822 $label = $langs->trans(
"ProspectLevel".$fk_prospectlevel);
4824 if ($label ==
"ProspectLevel".$fk_prospectlevel) {
4825 $label = $langs->getLabelFromKey($this->db, $fk_prospectlevel,
'c_prospectlevel',
'code',
'label');
4841 return $this->
LibProspCommStatut($this->stcomm_id, $mode, $label, $this->stcomm_picto);
4863 $langs->load(
'customers');
4866 if ($status ==
'-1' || $status ==
'ST_NO') {
4867 return img_action($langs->trans(
"StatusProspect-1"),
'-1', $picto,
'class="inline-block valignmiddle"').
' '.$langs->trans(
"StatusProspect-1");
4868 } elseif ($status ==
'0' || $status ==
'ST_NEVER') {
4869 return img_action($langs->trans(
"StatusProspect0"),
'0', $picto,
'class="inline-block valignmiddle"').
' '.$langs->trans(
"StatusProspect0");
4870 } elseif ($status ==
'1' || $status ==
'ST_TODO') {
4871 return img_action($langs->trans(
"StatusProspect1"),
'1', $picto,
'class="inline-block valignmiddle"').
' '.$langs->trans(
"StatusProspect1");
4872 } elseif ($status ==
'2' || $status ==
'ST_PEND') {
4873 return img_action($langs->trans(
"StatusProspect2"),
'2', $picto,
'class="inline-block valignmiddle"').
' '.$langs->trans(
"StatusProspect2");
4874 } elseif ($status ==
'3' || $status ==
'ST_DONE') {
4875 return img_action($langs->trans(
"StatusProspect3"),
'3', $picto,
'class="inline-block valignmiddle"').
' '.$langs->trans(
"StatusProspect3");
4877 return img_action(($langs->trans(
"StatusProspect".$status) !=
"StatusProspect".$status) ? $langs->trans(
"StatusProspect".$status) : $label,
'0', $picto,
'class="inline-block valignmiddle"').
' '.(($langs->trans(
"StatusProspect".$status) !=
"StatusProspect".$status) ? $langs->trans(
"StatusProspect".$status) : $label);
4879 } elseif ($mode == 3) {
4880 if ($status ==
'-1' || $status ==
'ST_NO') {
4881 return img_action($langs->trans(
"StatusProspect-1"),
'-1', $picto,
'class="inline-block valignmiddle"');
4882 } elseif ($status ==
'0' || $status ==
'ST_NEVER') {
4883 return img_action($langs->trans(
"StatusProspect0"),
'0', $picto,
'class="inline-block valignmiddle"');
4884 } elseif ($status ==
'1' || $status ==
'ST_TODO') {
4885 return img_action($langs->trans(
"StatusProspect1"),
'1', $picto,
'class="inline-block valignmiddle"');
4886 } elseif ($status ==
'2' || $status ==
'ST_PEND') {
4887 return img_action($langs->trans(
"StatusProspect2"),
'2', $picto,
'class="inline-block valignmiddle"');
4888 } elseif ($status ==
'3' || $status ==
'ST_DONE') {
4889 return img_action($langs->trans(
"StatusProspect3"),
'3', $picto,
'class="inline-block valignmiddle"');
4891 return img_action(($langs->trans(
"StatusProspect".$status) !=
"StatusProspect".$status) ? $langs->trans(
"StatusProspect".$status) : $label,
'0', $picto,
'class="inline-block valignmiddle"');
4893 } elseif ($mode == 4) {
4894 if ($status ==
'-1' || $status ==
'ST_NO') {
4895 return img_action($langs->trans(
"StatusProspect-1"),
'-1', $picto,
'class="inline-block valignmiddle"').
' '.$langs->trans(
"StatusProspect-1");
4896 } elseif ($status ==
'0' || $status ==
'ST_NEVER') {
4897 return img_action($langs->trans(
"StatusProspect0"),
'0', $picto,
'class="inline-block valignmiddle"').
' '.$langs->trans(
"StatusProspect0");
4898 } elseif ($status ==
'1' || $status ==
'ST_TODO') {
4899 return img_action($langs->trans(
"StatusProspect1"),
'1', $picto,
'class="inline-block valignmiddle"').
' '.$langs->trans(
"StatusProspect1");
4900 } elseif ($status ==
'2' || $status ==
'ST_PEND') {
4901 return img_action($langs->trans(
"StatusProspect2"),
'2', $picto,
'class="inline-block valignmiddle"').
' '.$langs->trans(
"StatusProspect2");
4902 } elseif ($status ==
'3' || $status ==
'ST_DONE') {
4903 return img_action($langs->trans(
"StatusProspect3"),
'3', $picto,
'class="inline-block valignmiddle"').
' '.$langs->trans(
"StatusProspect3");
4905 return img_action(($langs->trans(
"StatusProspect".$status) !=
"StatusProspect".$status) ? $langs->trans(
"StatusProspect".$status) : $label,
'0', $picto,
'class="inline-block valignmiddle"').
' '.(($langs->trans(
"StatusProspect".$status) !=
"StatusProspect".$status) ? $langs->trans(
"StatusProspect".$status) : $label);
4909 return "Error, mode/status not found";
4921 if ($mode ==
'supplier') {
4922 $table =
'supplier_proposal';
4925 $sql =
"SELECT rowid, ref, total_ht, total_ttc, fk_statut as status FROM ".MAIN_DB_PREFIX.$table.
" as f";
4926 $sql .=
" WHERE fk_soc = ".((int) $this->
id);
4927 if ($mode ==
'supplier') {
4928 $sql .=
" AND entity IN (".getEntity(
'supplier_proposal').
")";
4930 $sql .=
" AND entity IN (".getEntity(
'propal').
")";
4933 dol_syslog(
"getOutstandingProposals for fk_soc = ".((
int) $this->
id), LOG_DEBUG);
4935 $resql = $this->db->query($sql);
4937 $outstandingOpened = 0;
4938 $outstandingTotal = 0;
4939 $outstandingTotalIncTax = 0;
4940 $arrayofref = array();
4941 while ($obj = $this->db->fetch_object($resql)) {
4942 $arrayofref[$obj->rowid] = $obj->ref;
4943 $outstandingTotal += $obj->total_ht;
4944 $outstandingTotalIncTax += $obj->total_ttc;
4945 if ($obj->status != 0) {
4947 $outstandingOpened += $obj->total_ttc;
4950 return array(
'opened' => $outstandingOpened,
'total_ht' => $outstandingTotal,
'total_ttc' => $outstandingTotalIncTax,
'refs' => $arrayofref);
4964 $table =
'commande';
4965 if ($mode ==
'supplier') {
4966 $table =
'commande_fournisseur';
4969 $sql =
"SELECT rowid, ref, total_ht, total_ttc, fk_statut as status FROM ".MAIN_DB_PREFIX.$table.
" as f";
4970 $sql .=
" WHERE fk_soc = ".((int) $this->
id);
4971 if ($mode ==
'supplier') {
4972 $sql .=
" AND entity IN (".getEntity(
'supplier_order').
")";
4974 $sql .=
" AND entity IN (".getEntity(
'commande').
")";
4977 dol_syslog(
"getOutstandingOrders", LOG_DEBUG);
4978 $resql = $this->db->query($sql);
4980 $outstandingOpened = 0;
4981 $outstandingTotal = 0;
4982 $outstandingTotalIncTax = 0;
4983 $arrayofref = array();
4984 while ($obj = $this->db->fetch_object($resql)) {
4985 $arrayofref[$obj->rowid] = $obj->ref;
4986 $outstandingTotal += $obj->total_ht;
4987 $outstandingTotalIncTax += $obj->total_ttc;
4988 if ($obj->status != 0) {
4990 $outstandingOpened += $obj->total_ttc;
4993 return array(
'opened' => $outstandingOpened,
'total_ht' => $outstandingTotal,
'total_ttc' => $outstandingTotalIncTax,
'refs' => $arrayofref);
5009 if ($mode ==
'supplier') {
5010 $table =
'facture_fourn';
5022 $sql =
"SELECT rowid, ref, total_ht, total_ttc, paye, type, fk_statut as status, close_code FROM ".MAIN_DB_PREFIX.$table.
" as f";
5023 $sql .=
" WHERE fk_soc = ".((int) $this->
id);
5024 if (!empty($late)) {
5025 $sql .=
" AND date_lim_reglement < '".$this->db->idate($today).
"'";
5027 if ($mode ==
'supplier') {
5028 $sql .=
" AND entity IN (".getEntity(
'facture_fourn').
")";
5030 $sql .=
" AND entity IN (".getEntity(
'invoice').
")";
5033 dol_syslog(
"getOutstandingBills", LOG_DEBUG);
5034 $resql = $this->db->query($sql);
5036 $outstandingOpened = 0;
5037 $outstandingTotal = 0;
5038 $outstandingTotalIncTax = 0;
5039 $arrayofref = array();
5040 $arrayofrefopened = array();
5041 if ($mode ==
'supplier') {
5042 require_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.facture.class.php';
5045 require_once DOL_DOCUMENT_ROOT.
'/compta/facture/class/facture.class.php';
5046 $tmpobject =
new Facture($this->db);
5048 while ($obj = $this->db->fetch_object($resql)) {
5049 $arrayofref[$obj->rowid] = $obj->ref;
5050 $tmpobject->id = $obj->rowid;
5052 if ($obj->status != $tmpobject::STATUS_DRAFT
5053 && !($obj->status == $tmpobject::STATUS_ABANDONED && $obj->close_code ==
'replaced')
5055 $outstandingTotal += $obj->total_ht;
5056 $outstandingTotalIncTax += $obj->total_ttc;
5062 && $obj->status != $tmpobject::STATUS_DRAFT
5063 && $obj->status != $tmpobject::STATUS_ABANDONED
5064 && $obj->status != $tmpobject::STATUS_CLOSED) {
5066 $paiement = $tmpobject->getSommePaiement();
5067 $creditnotes = $tmpobject->getSumCreditNotesUsed();
5068 $deposits = $tmpobject->getSumDepositsUsed();
5070 $remaintopay = ($obj->total_ttc - $paiement - $creditnotes - $deposits);
5071 $outstandingOpened += $remaintopay;
5077 $remainingcreditnote = $tmpobject->getSumFromThisCreditNotesNotUsed();
5078 $remaintopay -= $remainingcreditnote;
5079 $outstandingOpened -= $remainingcreditnote;
5083 $arrayofrefopened[$obj->rowid] = $obj->ref;
5086 return array(
'opened' => $outstandingOpened,
'total_ht' => $outstandingTotal,
'total_ttc' => $outstandingTotalIncTax,
'refs' => $arrayofref,
'refsopened' => $arrayofrefopened);
5088 dol_syslog(
"Sql error ".$this->db->lasterror, LOG_ERR);
5115 $langs->load(
'companies');
5118 return $langs->trans(
"NorProspectNorCustomer");
5119 } elseif ($status == 1) {
5120 return $langs->trans(
"Customer");
5121 } elseif ($status == 2) {
5122 return $langs->trans(
"Prospect");
5123 } elseif ($status == 3) {
5124 return $langs->trans(
"ProspectCustomer");
5142 public function generateDocument($modele, $outputlangs, $hidedetails = 0, $hidedesc = 0, $hideref = 0, $moreparams =
null)
5146 if (!empty($moreparams) && !empty($moreparams[
'use_companybankid'])) {
5147 $modelpath =
"core/modules/bank/doc/";
5149 include_once DOL_DOCUMENT_ROOT.
'/societe/class/companybankaccount.class.php';
5151 $result = $companybankaccount->fetch($moreparams[
'use_companybankid']);
5153 dol_print_error($this->db, $companybankaccount->error, $companybankaccount->errors);
5155 $result = $companybankaccount->commonGenerateDocument($modelpath, $modele, $outputlangs, $hidedetails, $hidedesc, $hideref, $moreparams);
5156 $this->last_main_doc = $companybankaccount->last_main_doc;
5163 print $langs->trans(
"Error").
" ".$langs->trans(
"Error_COMPANY_ADDON_PDF_NotDefined");
5168 if (!isset($this->bank_account)) {
5169 require_once DOL_DOCUMENT_ROOT.
'/societe/class/companybankaccount.class.php';
5172 $result = $bac->fetch(0,
'', $this->
id);
5174 $this->bank_account = $bac;
5176 $this->bank_account =
'';
5180 $modelpath =
"core/modules/societe/doc/";
5182 $result = $this->
commonGenerateDocument($modelpath, $modele, $outputlangs, $hidedetails, $hidedesc, $hideref, $moreparams);
5202 require_once DOL_DOCUMENT_ROOT.
'/categories/class/categorie.class.php';
5205 if (!in_array($type_categ, array(Categorie::TYPE_CUSTOMER, Categorie::TYPE_SUPPLIER))) {
5206 dol_syslog(__METHOD__.
': Type '.$type_categ.
'is an unknown company category type. Done nothing.', LOG_ERR);
5210 return parent::setCategoriesCommon($categories, $type_categ);
5225 if (!is_array($salesrep)) {
5226 $salesrep = array($salesrep);
5230 $to_add = $salesrep;
5231 if ($onlyAdd ===
false) {
5236 if (is_array($existing)) {
5237 $to_del = array_diff($existing, $salesrep);
5238 $to_add = array_diff($salesrep, $existing);
5245 foreach ($to_del as $del) {
5248 foreach ($to_add as $add) {
5256 return $error ? -1 : 1;
5272 $result = $this->
setValueFrom(
'fk_typent', $typent_id,
'',
null,
'',
'', $user,
'COMPANY_MODIFY');
5275 $this->typent_id = $typent_id;
5276 $this->typent_code =
dol_getIdFromCode($this->db, $this->typent_id,
'c_typent',
'id',
'code');
5297 if ($origin_id == $dest_id) {
5298 dol_syslog(
'Error: Try to merge a thirdparty into itself');
5304 $sql =
'SELECT rowid FROM '.MAIN_DB_PREFIX.
'societe_commerciaux ';
5305 $sql .=
' WHERE fk_soc = '.(int) $dest_id.
' AND fk_user IN ( ';
5306 $sql .=
' SELECT fk_user ';
5307 $sql .=
' FROM '.MAIN_DB_PREFIX.
'societe_commerciaux ';
5308 $sql .=
' WHERE fk_soc = '.(int) $origin_id.
') ';
5310 $resql = $dbs->
query($sql);
5312 $dbs->
query(
'DELETE FROM '.MAIN_DB_PREFIX.
'societe_commerciaux WHERE rowid = '.((
int) $obj->rowid));
5319 'societe_commerciaux',
5322 'societe_remise_except',
5341 global $user, $langs,
$conf;
5345 if ($type ==
'buy') {
5346 $field =
'accountancy_code_buy';
5347 } elseif ($type ==
'sell') {
5348 $field =
'accountancy_code_sell';
5353 $sql =
"UPDATE ".MAIN_DB_PREFIX.$this->table_element.
" SET ";
5354 $sql .= $field.
" = '".$this->db->escape($value).
"'";
5355 $sql .=
" WHERE rowid = ".((int) $this->
id);
5357 dol_syslog(get_class($this).
"::".__FUNCTION__, LOG_DEBUG);
5358 $resql = $this->db->query($sql);
5362 include_once DOL_DOCUMENT_ROOT.
'/core/class/interfaces.class.php';
5364 $result = $interface->run_triggers(
'COMPANY_MODIFY', $this, $user, $langs,
$conf);
5366 $this->errors = $interface->errors;
5367 $this->db->rollback();
5372 $this->$field = $value;
5374 $this->db->commit();
5377 $this->error = $this->db->lasterror();
5378 $this->db->rollback();
5391 require_once DOL_DOCUMENT_ROOT.
'/partnership/class/partnership.class.php';
5393 $this->partnerships[] = array();
5407 $selected = (empty($arraydata[
'selected']) ? 0 : $arraydata[
'selected']);
5409 $return =
'<div class="box-flex-item box-flex-grow-zero">';
5410 $return .=
'<div class="info-box info-box-sm">';
5411 $return .=
'<span class="info-box-icon bg-infobox-action">';
5413 $return .=
'</span>';
5414 $return .=
'<div class="info-box-content">';
5415 $return .=
'<div class="info-box-ref inline-block tdoverflowmax125 valignmiddle">'.(method_exists($this,
'getNomUrl') ? $this->
getNomUrl(1) : $this->ref);
5416 $return .=
'</div>';
5417 if (!empty($this->phone)) {
5418 $return .=
'<div class="inline-block valignmiddle">';
5420 $return .=
dol_print_phone($this->phone, $this->country_code, 0, $this->
id,
'tel',
'hidenum',
'phone', $this->phone, 0,
'paddingleft paddingright');
5421 $return .=
'</div>';
5423 if (!empty($this->
email)) {
5424 $return .=
'<div class="inline-block valignmiddle">';
5425 $return .=
dol_print_email($this->
email, 0, $this->
id,
'thirdparty', -1, 1, 2,
'paddingleft paddingright');
5426 $return .=
'</div>';
5428 if ($selected >= 0) {
5429 $return .=
'<input id="cb'.$this->id.
'" class="flat checkforselect fright" type="checkbox" name="toselect[]" value="'.$this->
id.
'"'.($selected ?
' checked="checked"' :
'').
'>';
5431 if (property_exists($this,
'code_client')) {
5432 $return .=
'<br><span class="info-box-label opacitymedium">'.$this->code_client.
'</span>';
5434 if (method_exists($this,
'getLibStatut')) {
5435 $return .=
'<br><div class="info-box-status">'.$this->getLibStatut(3).
'</div>';
5437 $return .=
'</div>';
5438 $return .=
'</div>';
5439 $return .=
'</div>';
5460 $sql =
"SELECT sc.rowid, sc.fk_socpeople as id, sc.fk_c_type_contact";
5461 $sql .=
", t.fk_soc as socid, t.statut as statuscontact";
5462 $sql .=
", t.civility as civility, t.lastname as lastname, t.firstname, t.email";
5463 $sql .=
", tc.source, tc.element, tc.code, tc.libelle as type_label";
5464 $sql .=
" FROM ".$this->db->prefix().
"c_type_contact tc";
5465 $sql .=
", ".$this->db->prefix().
"societe_contacts sc";
5466 $sql .=
" LEFT JOIN ".$this->db->prefix().
"socpeople t on sc.fk_socpeople = t.rowid";
5467 $sql .=
" WHERE sc.fk_soc = ".((int) $this->
id);
5468 $sql .=
" AND sc.fk_c_type_contact = tc.rowid";
5469 if (!empty($element)) {
5470 $sql .=
" AND tc.element = '".$this->db->escape($element).
"'";
5473 $sql .=
" AND tc.code = '".$this->db->escape($code).
"'";
5475 $sql .=
" AND sc.entity IN (".getEntity($this->element).
")";
5476 $sql .=
" AND tc.source = 'external'";
5477 $sql .=
" AND tc.active = 1";
5479 $sql .=
" ORDER BY t.lastname ASC";
5481 dol_syslog(get_class($this).
"::getContacts", LOG_DEBUG);
5482 $resql = $this->db->query($sql);
5484 $num = $this->db->num_rows($resql);
5487 $obj = $this->db->fetch_object($resql);
5490 $transkey =
"TypeContact_".$obj->element.
"_".$obj->source.
"_".$obj->code;
5491 $libelle_type = ($langs->trans($transkey) != $transkey ? $langs->trans($transkey) : $obj->type_label);
5493 'source' => $obj->source,
5494 'socid' => $obj->socid,
5496 'nom' => $obj->lastname,
5497 'civility' => $obj->civility,
5498 'lastname' => $obj->lastname,
5499 'firstname' => $obj->firstname,
5500 'email' => $obj->email,
5501 'login' => (empty($obj->login) ?
'' : $obj->login),
5502 'photo' => (empty($obj->photo) ?
'' : $obj->photo),
5503 'statuscontact' => $obj->statuscontact,
5504 'rowid' => $obj->rowid,
5505 'code' => $obj->code,
5506 'element' => $obj->element,
5507 'libelle' => $libelle_type,
5508 'status' => $obj->statuslink,
5509 'fk_c_type_contact' => $obj->fk_c_type_contact
5512 $tab[$i] = $obj->id;
5520 $this->error = $this->db->lasterror();
5538 global
$conf, $langs, $hookmanager, $user, $action;
5541 $soc_origin =
new Societe($this->db);
5543 dol_syslog(
"mergeCompany merge thirdparty id=".$soc_origin_id.
" (will be deleted) into the thirdparty id=".$this->id);
5545 if (!$error && $soc_origin->fetch($soc_origin_id) < 1) {
5546 $this->error = $langs->trans(
'ErrorRecordNotFound');
5554 $this->client |= $soc_origin->client;
5555 $this->fournisseur |= $soc_origin->fournisseur;
5556 $listofproperties = array(
5557 'address',
'zip',
'town',
'state_id',
'country_id',
'phone',
'phone_mobile',
'fax',
'email',
'socialnetworks',
'url',
'barcode',
5558 'idprof1',
'idprof2',
'idprof3',
'idprof4',
'idprof5',
'idprof6',
5559 'tva_intra',
'effectif_id',
'forme_juridique',
'remise_percent',
'remise_supplier_percent',
'mode_reglement_supplier_id',
'cond_reglement_supplier_id',
'name_bis',
5560 'stcomm_id',
'outstanding_limit',
'order_min_amount',
'supplier_order_min_amount',
'price_level',
'parent',
'default_lang',
'ref',
'ref_ext',
'import_key',
'fk_incoterms',
'fk_multicurrency',
5561 'code_client',
'code_fournisseur',
'code_compta',
'code_compta_fournisseur',
5562 'model_pdf',
'webservices_url',
'webservices_key',
'accountancy_code_sell',
'accountancy_code_buy',
'typent_id'
5564 foreach ($listofproperties as $property) {
5565 if (empty($this->$property)) {
5566 $this->$property = $soc_origin->$property;
5570 if ($this->typent_id == -1) {
5571 $this->typent_id = $soc_origin->typent_id;
5575 $listofproperties = array(
5576 'note_public',
'note_private'
5578 foreach ($listofproperties as $property) {
5579 $this->$property =
dol_concatdesc($this->$property, $soc_origin->$property);
5583 if (is_array($soc_origin->array_options)) {
5584 foreach ($soc_origin->array_options as $key => $val) {
5585 if (empty($this->array_options[$key])) {
5586 $this->array_options[$key] = $val;
5592 if (empty($this->name_bis) && $this->
name != $soc_origin->name) {
5593 $this->name_bis = $this->name;
5597 include_once DOL_DOCUMENT_ROOT.
'/categories/class/categorie.class.php';
5600 $custcats_ori = $static_cat->containing($soc_origin->id,
'customer',
'id');
5601 $custcats = $static_cat->containing($this->
id,
'customer',
'id');
5602 $custcats = array_merge($custcats, $custcats_ori);
5605 $suppcats_ori = $static_cat->containing($soc_origin->id,
'supplier',
'id');
5606 $suppcats = $static_cat->containing($this->
id,
'supplier',
'id');
5607 $suppcats = array_merge($suppcats, $suppcats_ori);
5611 if ($soc_origin->code_client == $this->code_client
5612 || $soc_origin->code_fournisseur == $this->code_fournisseur
5613 || $soc_origin->barcode == $this->barcode) {
5614 dol_syslog(
"We clean customer and supplier code so we will be able to make the update of target");
5615 $soc_origin->code_client =
'';
5616 $soc_origin->code_fournisseur =
'';
5617 $soc_origin->barcode =
'';
5618 $soc_origin->update($soc_origin->id, $user, 0, 1, 1,
'merge');
5622 $result = $this->
update($this->
id, $user, 0, 1, 1,
'merge');
5631 'Adherent' =>
'/adherents/class/adherent.class.php',
5633 'ActionComm' =>
'/comm/action/class/actioncomm.class.php',
5634 'Propal' =>
'/comm/propal/class/propal.class.php',
5635 'Commande' =>
'/commande/class/commande.class.php',
5636 'Facture' =>
'/compta/facture/class/facture.class.php',
5637 'FactureRec' =>
'/compta/facture/class/facture-rec.class.php',
5638 'LignePrelevement' =>
'/compta/prelevement/class/ligneprelevement.class.php',
5639 'Contact' =>
'/contact/class/contact.class.php',
5640 'Contrat' =>
'/contrat/class/contrat.class.php',
5641 'Expedition' =>
'/expedition/class/expedition.class.php',
5642 'CommandeFournisseur' =>
'/fourn/class/fournisseur.commande.class.php',
5643 'FactureFournisseur' =>
'/fourn/class/fournisseur.facture.class.php',
5644 'FactureFournisseurRec' =>
'/fourn/class/fournisseur.facture-rec.class.php',
5645 'Reception' =>
'/reception/class/reception.class.php',
5646 'SupplierProposal' =>
'/supplier_proposal/class/supplier_proposal.class.php',
5647 'ProductFournisseur' =>
'/fourn/class/fournisseur.product.class.php',
5648 'Product' =>
'/product/class/product.class.php',
5650 'Project' =>
'/projet/class/project.class.php',
5651 'User' =>
'/user/class/user.class.php',
5652 'Account' =>
'/compta/bank/class/account.class.php',
5653 'ConferenceOrBoothAttendee' =>
'/eventorganization/class/conferenceorboothattendee.class.php',
5654 'Societe' =>
'/societe/class/societe.class.php',
5657 if ($this->db->DDLListTables(
$conf->db->name, $this->db->prefix().
'delivery')) {
5658 $objects[
'Delivery'] =
'/delivery/class/delivery.class.php';
5660 if ($this->db->DDLListTables(
$conf->db->name, $this->db->prefix().
'mrp_mo')) {
5661 $objects[
'Mo'] =
'/mrp/class/mo.class.php';
5663 if ($this->db->DDLListTables(
$conf->db->name, $this->db->prefix().
'don')) {
5664 $objects[
'Don'] =
'/don/class/don.class.php';
5666 if ($this->db->DDLListTables(
$conf->db->name, $this->db->prefix().
'partnership')) {
5667 $objects[
'PartnerShip'] =
'/partnership/class/partnership.class.php';
5669 if ($this->db->DDLListTables(
$conf->db->name, $this->db->prefix().
'fichinter')) {
5670 $objects[
'Fichinter'] =
'/fichinter/class/fichinter.class.php';
5672 if ($this->db->DDLListTables(
$conf->db->name, $this->db->prefix().
'ticket')) {
5673 $objects[
'Ticket'] =
'/ticket/class/ticket.class.php';
5677 foreach ($objects as $object_name => $object_file) {
5687 require_once DOL_DOCUMENT_ROOT.$object_file;
5689 if (!$error && !$object_name::replaceThirdparty($this->db, $soc_origin->id, $this->id)) {
5691 $this->error = $this->db->lasterror();
5699 $parameters = array(
'soc_origin' => $soc_origin->id,
'soc_dest' => $this->id);
5700 $reshook = $hookmanager->executeHooks(
'replaceThirdparty', $parameters, $this, $action);
5703 $this->error = $hookmanager->error;
5704 $this->errors = $hookmanager->errors;
5711 $this->context = array(
'merge' => 1,
'mergefromid' => $soc_origin->id,
'mergefromname' => $soc_origin->name);
5714 $result = $this->
call_trigger(
'COMPANY_MODIFY', $user);
5723 if ($soc_origin->delete($soc_origin->id, $user) < 1) {
5724 $this->error = $soc_origin->error;
5725 $this->errors = $soc_origin->errors;
5733 if (!empty(
$conf->societe->multidir_output[$this->entity])) {
5734 $srcdir =
$conf->societe->multidir_output[$this->entity].
"/".$soc_origin->id;
5735 $destdir =
$conf->societe->multidir_output[$this->entity].
"/".$this->id;
5739 foreach ($dirlist as $filetomove) {
5740 $destfile = $destdir.
'/'.$filetomove[
'relativename'];
5742 dol_move($filetomove[
'fullname'], $destfile,
'0', 0, 0, 1);
5750 $this->db->commit();
5753 $langs->load(
"errors");
5754 $this->error = $langs->trans(
'ErrorsThirdpartyMerge');
5755 $this->db->rollback();
Class to manage members of a foundation.
Class to manage withdrawal receipts.
Class to manage categories.
Parent class of all other business classes (invoices, contracts, proposals, orders,...
fetch_optionals($rowid=null, $optionsArray=null)
Function to get extra fields of an object into $this->array_options This method is in most cases call...
commonGenerateDocument($modelspath, $modele, $outputlangs, $hidedetails, $hidedesc, $hideref, $moreparams=null)
Common function for all objects extending CommonObject for generating documents.
setErrorsFromObject($object)
setErrorsFromObject
isObjectUsed($id=0, $entity=0)
Function to check if an object is used by others (by children).
deleteExtraFields()
Delete all extra fields values for the current object.
insertExtraLanguages($trigger='', $userused=null)
Add/Update all extra fields values for the current object.
static commonReplaceThirdparty(DoliDB $dbs, $origin_id, $dest_id, array $tables, $ignoreerrors=0)
Function used to replace a thirdparty id with another one.
setValueFrom($field, $value, $table='', $id=null, $format='', $id_field='', $fuser=null, $trigkey='', $fk_user_field='fk_user_modif')
Setter generic.
insertExtraFields($trigger='', $userused=null)
Add/Update all extra fields values for the current object.
call_trigger($triggerName, $user)
Call trigger based on this instance.
Class to manage bank accounts description of third parties.
Class to stock current configuration.
Class to manage absolute discounts.
Class to manage Dolibarr database access.
Class to manage suppliers invoices.
const TYPE_CREDIT_NOTE
Credit note invoice.
Class to manage invoices.
Class to manage triggers.
static getIdFromCode($dbs, $code)
Get id of currency from code.
Class to manage third parties objects (customers, suppliers, prospects...)
setParent($id)
Define parent company of current company.
getLibProspLevel()
Return prostect level.
thirdparty_and_contact_email_array($addthirdparty=0)
Return list of contacts emails existing for third party.
setAsCustomer()
Define third party as a customer.
findNearest($rowid=0, $ref='', $ref_ext='', $barcode='', $idprof1='', $idprof2='', $idprof3='', $idprof4='', $idprof5='', $idprof6='', $email='', $ref_alias='', $is_client=0, $is_supplier=0)
Search the thirdparty that match the most the provided parameters.
codefournisseur_modifiable()
Check if a vendor code is editable in the code control module configuration.
contact_get_property($rowid, $mode)
Return property of contact from its id.
check_codeclient()
Check customer code.
verify()
Check properties of third party are ok (like name, third party codes, ...) Used before an add or upda...
getContacts($list=0, $code='', $element='')
Get array of all contacts for a society (stored in societe_contacts instead of element_contacts for a...
LibProspCommStatut($status, $mode=0, $label='', $picto='')
Return label of a given status.
static replaceThirdparty(DoliDB $dbs, $origin_id, $dest_id)
Function used to replace a thirdparty id with another one.
get_all_rib()
Return Array of RIB.
get_codecompta($type)
Assigns a accounting code from the accounting code module.
__construct($db)
Constructor.
del_commercial(User $user, $commid)
Add link to sales representative.
info($id)
Load information for tab info.
has_projects()
Indicates if the company has projects.
setThirdpartyType($typent_id)
Define third-party type of current company.
isACompany()
Check if third party is a company (Business) or an end user (Consumer)
getOutstandingBills($mode='customer', $late=0)
Return amount of bill not yet paid and total of all invoices.
add_commercial(User $user, $commid)
Add link to sales representative.
LibStatut($status, $mode=0)
Return the label of a given status.
update($id, User $user, $call_trigger=1, $allowmodcodeclient=0, $allowmodcodefournisseur=0, $action='update', $nosyncmember=1)
Update parameters of third party.
const PROSPECT
Third party type is a prospect.
create(User $user, $notrigger=0)
Create third party in database.
set_as_client()
Define third party as a customer.
getOutstandingOrders($mode='customer')
Return amount of order not yet paid and total and list of all orders.
id_prof_exists($idprof, $value, $socid=0)
Verify if a profid exists into database for others thirds.
setCategories($categories, $type_categ)
Sets object to supplied categories.
useRevenueStamp()
Check if we must use revenue stamps feature or not according to country (country of $mysoc in most ca...
setNoEmail($no_email)
Set "blacklist" mailing status.
id_prof_verifiable($idprof)
Returns if a profid should be verified to be unique.
create_from_member(Adherent $member, $socname='', $socalias='', $customercode='')
Create a third party into database from a member object.
getParentsForCompany($company_id, $parents=array())
Get parents for company.
set_remise_except($remise, User $user, $desc, $vatrate='', $discount_type=0, $price_base_type='HT')
Add a discount for third party.
const CUSTOMER_AND_PROSPECT
Third party type is a customer and a prospect.
generateDocument($modele, $outputlangs, $hidedetails=0, $hidedesc=0, $hideref=0, $moreparams=null)
Create a document onto disk according to template module.
set_remise_client($remise, $note, User $user)
Defines the company as a customer.
getOutstandingProposals($mode='customer')
Return amount of proposal not yet paid and total an dlist of all proposals.
const CUSTOMER
Third party type is a customer.
fetch($rowid, $ref='', $ref_ext='', $barcode='', $idprof1='', $idprof2='', $idprof3='', $idprof4='', $idprof5='', $idprof6='', $email='', $ref_alias='', $is_client=0, $is_supplier=0)
Load a third party from database into memory.
getSalesRepresentatives(User $user, $mode=0, $sortfield=null, $sortorder=null)
Return array of sales representatives.
LoadSupplierCateg()
Load the list of provider categories.
getAvailableDiscounts($user=null, $filter='', $maxvalue=0, $discount_type=0)
Returns amount of included taxes of the current discounts/credits available from the company.
display_rib($mode='label')
Return bank number property of thirdparty (label or rum)
contact_array_objects()
Return the contact list of this company.
isInEEC()
Return if a company is inside the EEC (European Economic Community)
codeclient_modifiable()
Check if a client code is editable based on the parameters of the code control module.
fetchPartnerships($mode)
Function to get partnerships array.
validateFamilyTree($idparent, $idchild, $counter=0)
Check if a thirdparty $idchild is or not inside the parents (or grand parents) of another thirdparty ...
mergeCompany($soc_origin_id)
Merge a company with current one, deleting the given company $soc_origin_id.
const NO_SUPPLIER
Third party supplier flag is not supplier.
getNbOfEMailings()
Return number of mass Emailing received by this contacts with its email.
setAccountancyCode($type, $value)
Sets an accountancy code for a thirdparty.
getLibCustProspStatut()
Return label of status customer is prospect/customer.
getNomUrl($withpicto=0, $option='', $maxlen=0, $notooltip=0, $save_lastsearch_value=-1, $noaliasinname=0, $target='', $morecss='')
Return a link on thirdparty (with picto)
getLibStatut($mode=0)
Return label of status (activity, closed)
const NO_CUSTOMER
Third party type is no customer.
LibProspLevel($fk_prospectlevel)
Return label of prospect level.
set_remise_supplier($remise, $note, User $user)
Defines the company as a customer.
useLocalTax($localTaxNum=0)
Check if we must use localtax feature or not according to country (country of $mysoc in most cases).
create_individual(User $user, $no_email=0, $tags=array(), $notrigger=0)
Create a contact/address from thirdparty.
getNoEmail()
get "blacklist" mailing status set no_email attribute to 1 or 0
getLibProspCommStatut($mode=0, $label='')
Return status of prospect.
AddFournisseurInCategory($categorie_id)
Insert link supplier - category.
contact_property_array($mode='email', $hidedisabled=0)
Return list of contacts emails or mobile existing for third party.
LibCustProspStatut($status)
Return the label of the customer/prospect status.
id_prof_check($idprof, $soc)
Check the validity of a professional identifier according to the country of the company (siren,...
getTypeUrl($withpicto=0, $option='', $notooltip=0, $tag='a')
Return link(s) on type of thirdparty (with picto)
setPriceLevel($price_level, User $user)
Set the price level.
thirdparty_and_contact_phone_array()
Return list of contacts mobile phone existing for third party.
deprecatedProperties()
Provide list of deprecated properties and replacements.
getTooltipContentArray($params)
getTooltipContentArray
useNPR()
Check if we must use NPR Vat (french stupid rule) or not according to country (country of $mysoc in m...
setSalesRep($salesrep, $onlyAdd=false)
Sets sales representatives of the thirdparty.
getKanbanView($option='', $arraydata=array())
Return clickable link of object (with optional picto)
const SUPPLIER
Third party supplier flag is a supplier.
check_codefournisseur()
Check supplier code.
contact_array()
Return the contact list of this company.
initAsSpecimen()
Initialise an instance with random values.
id_prof_url($idprof, $thirdparty)
Return an url to check online a professional id or empty string.
setMysoc(Conf $conf)
Set properties with value into $conf.
Class to manage Dolibarr users.
print $langs trans("Ref").' m titre as m m statut as status
Or an array listing all the potential status of the object: array: int of the status => translated la...
setUpperOrLowerCase()
Set to upper or ucwords/lower if needed.
trait CommonSocialNetworks
Superclass for social networks.
getCountry($searchkey, $withcode='', $dbtouse=null, $outputlangs=null, $entconv=1, $searchlabel='')
Return country label, code or id from an id, code or label.
getState($id, $withcode='0', $dbtouse=null, $withregion=0, $outputlangs=null, $entconv=1)
Return state translated from an id.
dol_get_first_hour($date, $gm='tzserver')
Return GMT time for first hour of a given GMT date (it removes hours, min and second part)
print $script_file $mode $langs defaultlang(is_numeric($duration_value) ? " delay=". $duration_value :"").(is_numeric($duration_value2) ? " after cd cd cd description as p label as s rowid as s nom as s email
Sender: Who sends the email ("Sender" has sent emails on behalf of "From").
dol_move($srcfile, $destfile, $newmask='0', $overwriteifexists=1, $testvirus=0, $indexdatabase=1, $moreinfo=array(), $entity=0)
Move a file into another name.
dol_delete_dir_recursive($dir, $count=0, $nophperrors=0, $onlysub=0, &$countdeleted=0, $indexdatabase=1, $nolog=0, $level=0)
Remove a directory $dir and its subdirectories (or only files and subdirectories)
dol_dir_list($utf8_path, $types="all", $recursive=0, $filter="", $excludefilter=null, $sortcriteria="name", $sortorder=SORT_ASC, $mode=0, $nohook=0, $relativename="", $donotfollowsymlinks=0, $nbsecondsold=0)
Scan a directory and return a list of files/directories.
dol_is_dir($folder)
Test if filename is a directory.
clean_url($url, $http=1)
Clean an url string.
dol_getIdFromCode($db, $key, $tablename, $fieldkey='code', $fieldid='id', $entityfilter=0, $filters='', $useCache=true)
Return an id or code from a code or id.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
setEntity($currentobject)
Set entity id to use when to create an object.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
Show picto whatever it's its name (generic function)
dol_format_address($object, $withcountry=0, $sep="\n", $outputlangs=null, $mode=0, $extralangcode='')
Return a formatted address (part address/zip/town/state) according to country rules.
dol_print_phone($phone, $countrycode='', $cid=0, $socid=0, $addlink='', $separ=" ", $withpicto='', $titlealt='', $adddivfloat=0, $morecss='paddingright')
Format phone numbers according to country.
dol_string_nohtmltag($stringtoclean, $removelinefeed=1, $pagecodeto='UTF-8', $strip_tags=0, $removedoublespaces=1)
Clean a string from all HTML tags and entities.
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
dol_string_nospecial($str, $newstr='_', $badcharstoreplace='', $badcharstoremove='', $keepspaces=0)
Clean a string from all punctuation characters to use it as a ref or login.
img_action($titlealt, $numaction, $picto='', $moreatt='')
Show logo action.
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $allowothertags=array())
Show a picto called object_picto (generic function)
setEventMessage($mesgs, $style='mesgs', $noduplicate=0, $attop=0)
Set event message in dol_events session object.
dol_strlen($string, $stringencoding='UTF-8')
Make a strlen call.
dol_now($mode='auto')
Return date for now.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
if(!function_exists( 'dol_getprefix')) dol_include_once($relpath, $classname='')
Make an include_once using default root and alternate root if it fails.
dolGetFirstLastname($firstname, $lastname, $nameorder=-1)
Return firstname and lastname in correct order.
dol_concatdesc($text1, $text2, $forxml=false, $invert=false)
Concat 2 descriptions with a new line between them (second operand after first one with appropriate n...
dolPrintHTMLForAttribute($s, $escapeonlyhtmltags=0, $allowothertags=array())
Return a string ready to be output into an HTML attribute (alt, title, data-html, ....
dol_print_email($email, $cid=0, $socid=0, $addlink=0, $max=64, $showinvalid=1, $withpicto=0, $morecss='paddingrightonly')
Show EMail link formatted for HTML output.
dolGetStatus($statusLabel='', $statusLabelShort='', $html='', $statusType='status0', $displayMode=0, $url='', $params=array())
Output the badge of a status.
getDolGlobalBool($key, $default=false)
Return a Dolibarr global constant boolean value.
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
dol_trunc($string, $size=40, $trunc='right', $stringencoding='UTF-8', $nodot=0, $display=0)
Truncate a string to a particular length adding '…' if string larger than length.
isValidEmail($address, $acceptsupervisorkey=0, $acceptuserkey=0)
Return true if email syntax is ok.
dol_sanitizeFileName($str, $newstr='_', $unaccent=1, $includequotes=0)
Clean a string to use it as a file name.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
getEntity($element, $shared=1, $currentobject=null)
Get list of entity id to use.
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0, $cleanalsojavascript=0)
Returns text escaped for inclusion in HTML alt or title or value tags, or into values of HTML input f...
div refaddress div address
query($query, $usesavepoint=0, $type='auto', $result_mode=0)
Execute a SQL request and return the resultset.
fetch_object($resultset)
Returns the current line (as an object) for the resultset cursor.
global $conf
The following vars must be defined: $type2label $form $conf, $lang, The following vars may also be de...
isValidSiren($siren)
Check the syntax validity of a SIREN.
isValidTinForPT($str)
Check the syntax validity of a Portuguese (PT) Tax Identification Number (TIN).
isValidSiret($siret)
Check the syntax validity of a SIRET.
isValidTinForES($str)
Check the syntax validity of a Spanish (ES) Tax Identification Number (TIN), where:
isValidTinForBE($str)
Check the syntax validity of a Belgium (BE) Tax Identification Number (TIN).
isValidTinForDZ($str)
Check the syntax validity of an Algerian (DZ) Tax Identification Number (TIN).
$conf db name
Only used if Module[ID]Name translation string is not found.