2006-02-25 00:16:35 +01:00
< ? php
2008-06-24 10:41:28 +02:00
/* Copyright ( C ) 2002 - 2004 Rodolphe Quiedeville < rodolphe @ quiedeville . org >
* Copyright ( C ) 2004 Benoit Mortier < benoit . mortier @ opensides . be >
2013-05-03 00:15:02 +02:00
* Copyright ( C ) 2004 - 2013 Laurent Destailleur < eldy @ users . sourceforge . net >
2018-10-27 14:43:12 +02:00
* Copyright ( C ) 2005 - 2012 Regis Houssin < regis . houssin @ inodbox . com >
2008-06-24 10:41:28 +02:00
* Copyright ( C ) 2007 Franky Van Liedekerke < franky . van . liedekerker @ telenet . be >
* Copyright ( C ) 2008 Raphael Bertrand ( Resultic ) < raphael . bertrand @ resultic . fr >
2019-03-29 12:11:50 +01:00
* Copyright ( C ) 2013 Florian Henry < florian . henry @ open - concept . pro >
2019-01-28 21:39:22 +01:00
* Copyright ( C ) 2013 Alexandre Spangaro < aspangaro @ open - dsi . fr >
2014-01-30 12:20:36 +01:00
* Copyright ( C ) 2013 Juanjo Menent < jmenent @ 2 byte . es >
2015-04-18 20:50:03 +02:00
* Copyright ( C ) 2015 Marcos GarcÃa < marcosgdf @ gmail . com >
2019-12-20 11:14:16 +01:00
* Copyright ( C ) 2019 Nicolas ZABOURI < info @ inovea - conseil . com >
2020-04-27 17:35:14 +02:00
* Copyright ( C ) 2020 Open - Dsi < support @ open - dsi . fr >
2006-02-25 00:16:35 +01:00
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
2013-01-16 15:36:08 +01:00
* the Free Software Foundation ; either version 3 of the License , or
2006-02-25 00:16:35 +01:00
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
2019-09-23 21:55:30 +02:00
* along with this program . If not , see < https :// www . gnu . org / licenses />.
2006-02-25 00:16:35 +01:00
*/
/**
2010-06-06 16:30:28 +02:00
* \file htdocs / contact / class / contact . class . php
2009-08-12 02:15:40 +02:00
* \ingroup societe
2010-02-21 14:08:02 +01:00
* \brief File of contacts class
2009-08-11 14:51:33 +02:00
*/
2019-11-08 15:51:54 +01:00
require_once DOL_DOCUMENT_ROOT . '/core/class/commonobject.class.php' ;
2007-11-05 23:37:41 +01:00
2006-02-25 00:16:35 +01:00
/**
2012-11-15 14:52:19 +01:00
* Class to manage contact / addresses
2009-08-11 14:51:33 +02:00
*/
2007-11-05 23:37:41 +01:00
class Contact extends CommonObject
2006-02-25 00:16:35 +01:00
{
2018-08-23 18:17:09 +02:00
/**
* @ var string ID to identify managed object
*/
2019-11-08 15:51:54 +01:00
public $element = 'contact' ;
2018-09-02 18:18:10 +02:00
2018-08-22 18:34:50 +02:00
/**
* @ var string Name of table without prefix where object is stored
*/
2019-11-08 15:51:54 +01:00
public $table_element = 'socpeople' ;
2018-09-02 18:18:10 +02:00
2018-10-06 12:11:48 +02:00
/**
* 0 = No test on entity , 1 = Test with field entity , 2 = Test with link by societe
* @ var int
*/
public $ismultientitymanaged = 1 ;
2018-09-05 12:21:13 +02:00
/**
* @ var string String with name of icon for myobject . Must be the part after the 'object_' into object_myobject . png
*/
2017-11-02 15:03:09 +01:00
public $picto = 'contact' ;
2009-01-19 23:41:26 +01:00
2020-09-29 14:59:16 +02:00
/**
* 'type' if the field format ( 'integer' , 'integer:ObjectClass:PathToClass[:AddCreateButtonOrNot[:Filter]]' , 'varchar(x)' , 'double(24,8)' , 'real' , 'price' , 'text' , 'html' , 'date' , 'datetime' , 'timestamp' , 'duration' , 'mail' , 'phone' , 'url' , 'password' )
* Note : Filter can be a string like " (t.ref:like:'SO-%') or (t.date_creation:<:'20160101') or (t.nature:is:NULL) "
* 'label' the translation key .
* 'enabled' is a condition when the field must be managed .
* 'position' is the sort order of field .
* 'notnull' is set to 1 if not null in database . Set to - 1 if we must set data to null if empty ( '' or 0 ) .
* 'visible' says if field is visible in list ( Examples : 0 = Not visible , 1 = Visible on list and create / update / view forms , 2 = Visible on list only , 3 = Visible on create / update / view form only ( not list ), 4 = Visible on list and update / view form only ( not create ) . 5 = Visible on list and view only ( not create / not update ) . Using a negative value means field is not shown by default on list but can be selected for viewing )
* 'noteditable' says if field is not editable ( 1 or 0 )
* 'default' is a default value for creation ( can still be overwrote by the Setup of Default Values if field is editable in creation form ) . Note : If default is set to '(PROV)' and field is 'ref' , the default value will be set to '(PROVid)' where id is rowid when a new record is created .
* 'index' if we want an index in database .
* 'foreignkey' => 'tablename.field' if the field is a foreign key ( it is recommanded to name the field fk_ ... ) .
* 'searchall' is 1 if we want to search in this field when making a search from the quick search button .
* 'isameasure' must be set to 1 if you want to have a total on list for this field . Field type must be summable like integer or double ( 24 , 8 ) .
* 'css' is the CSS style to use on field . For example : 'maxwidth200'
* 'help' is a string visible as a tooltip on field
* 'showoncombobox' if value of the field must be visible into the label of the combobox that list record
* 'disabled' is 1 if we want to have the field locked by a 'disabled' attribute . In most cases , this is never set into the definition of $fields into class , but is set dynamically by some part of code .
2021-04-29 12:10:55 +02:00
* 'arrayofkeyval' to set list of value if type is a list of predefined values . For example : array ( " 0 " => " Draft " , " 1 " => " Active " , " -1 " => " Cancel " )
2020-09-29 14:59:16 +02:00
* 'comment' is not used . You can store here any text of your choice . It is not used by application .
*
* Note : To have value dynamic , you can set value to 0 in definition and edit the value on the fly into the constructor .
*/
2018-01-31 10:51:40 +01:00
// BEGIN MODULEBUILDER PROPERTIES
/**
* @ var array Array with all fields and their property . Do not use it as a static var . It may be modified by constructor .
*/
2020-02-18 23:47:25 +01:00
public $fields = array (
2019-12-20 11:14:16 +01:00
'rowid' => array ( 'type' => 'integer' , 'label' => 'TechnicalID' , 'enabled' => 1 , 'visible' =>- 1 , 'notnull' => 1 , 'position' => 10 ),
2020-09-30 11:45:29 +02:00
'entity' => array ( 'type' => 'integer' , 'label' => 'Entity' , 'default' => 1 , 'enabled' => 1 , 'visible' => 3 , 'notnull' => 1 , 'position' => 30 , 'index' => 1 ),
'ref_ext' => array ( 'type' => 'varchar(255)' , 'label' => 'Ref ext' , 'enabled' => 1 , 'visible' => 3 , 'position' => 35 ),
2020-09-29 14:59:16 +02:00
'civility' => array ( 'type' => 'varchar(6)' , 'label' => 'Civility' , 'enabled' => 1 , 'visible' => 3 , 'position' => 40 ),
'lastname' => array ( 'type' => 'varchar(50)' , 'label' => 'Lastname' , 'enabled' => 1 , 'visible' => 1 , 'position' => 45 , 'showoncombobox' => 1 , 'searchall' => 1 ),
'firstname' => array ( 'type' => 'varchar(50)' , 'label' => 'Firstname' , 'enabled' => 1 , 'visible' => 1 , 'position' => 50 , 'showoncombobox' => 1 , 'searchall' => 1 ),
2021-09-06 12:51:40 +02:00
'poste' => array ( 'type' => 'varchar(80)' , 'label' => 'PostOrFunction' , 'enabled' => 1 , 'visible' =>- 1 , 'position' => 52 ),
2020-09-30 11:45:29 +02:00
'address' => array ( 'type' => 'varchar(255)' , 'label' => 'Address' , 'enabled' => 1 , 'visible' =>- 1 , 'position' => 55 ),
2020-09-29 14:59:16 +02:00
'zip' => array ( 'type' => 'varchar(25)' , 'label' => 'Zip' , 'enabled' => 1 , 'visible' => 1 , 'position' => 60 ),
2021-07-03 18:38:43 +02:00
'town' => array ( 'type' => 'text' , 'label' => 'Town' , 'enabled' => 1 , 'visible' =>- 1 , 'position' => 65 ),
2020-09-30 11:45:29 +02:00
'fk_departement' => array ( 'type' => 'integer' , 'label' => 'Fk departement' , 'enabled' => 1 , 'visible' => 3 , 'position' => 70 ),
'fk_pays' => array ( 'type' => 'integer' , 'label' => 'Fk pays' , 'enabled' => 1 , 'visible' => 3 , 'position' => 75 ),
2021-09-06 12:51:40 +02:00
'fk_soc' => array ( 'type' => 'integer' , 'label' => 'ThirdParty' , 'enabled' => 1 , 'visible' => 1 , 'position' => 77 , 'searchall' => 1 ),
2020-09-30 11:45:29 +02:00
'birthday' => array ( 'type' => 'date' , 'label' => 'Birthday' , 'enabled' => 1 , 'visible' => 3 , 'position' => 80 ),
2020-09-29 14:59:16 +02:00
'phone' => array ( 'type' => 'varchar(30)' , 'label' => 'Phone' , 'enabled' => 1 , 'visible' => 1 , 'position' => 90 , 'searchall' => 1 ),
2021-07-03 18:38:43 +02:00
'phone_perso' => array ( 'type' => 'varchar(30)' , 'label' => 'PhonePerso' , 'enabled' => 1 , 'visible' =>- 1 , 'position' => 95 , 'searchall' => 1 ),
2020-09-29 14:59:16 +02:00
'phone_mobile' => array ( 'type' => 'varchar(30)' , 'label' => 'PhoneMobile' , 'enabled' => 1 , 'visible' => 1 , 'position' => 100 , 'searchall' => 1 ),
2021-07-03 18:38:43 +02:00
'fax' => array ( 'type' => 'varchar(30)' , 'label' => 'Fax' , 'enabled' => 1 , 'visible' =>- 1 , 'position' => 105 , 'searchall' => 1 ),
2020-09-29 14:59:16 +02:00
'email' => array ( 'type' => 'varchar(255)' , 'label' => 'Email' , 'enabled' => 1 , 'visible' => 1 , 'position' => 110 , 'searchall' => 1 ),
'socialnetworks' => array ( 'type' => 'text' , 'label' => 'SocialNetworks' , 'enabled' => 1 , 'visible' => 3 , 'position' => 115 ),
'photo' => array ( 'type' => 'varchar(255)' , 'label' => 'Photo' , 'enabled' => 1 , 'visible' => 3 , 'position' => 170 ),
'priv' => array ( 'type' => 'smallint(6)' , 'label' => 'ContactVisibility' , 'enabled' => 1 , 'visible' => 1 , 'notnull' => 1 , 'position' => 175 ),
2021-09-06 12:51:40 +02:00
'fk_stcommcontact' => array ( 'type' => 'integer' , 'label' => 'ProspectStatus' , 'enabled' => 1 , 'visible' =>- 1 , 'notnull' => 1 , 'position' => 220 ),
2020-09-30 11:52:22 +02:00
'fk_prospectlevel' => array ( 'type' => 'varchar(12)' , 'label' => 'ProspectLevel' , 'enabled' => 1 , 'visible' =>- 1 , 'position' => 255 ),
2020-09-29 14:59:16 +02:00
'no_email' => array ( 'type' => 'smallint(6)' , 'label' => 'No_Email' , 'enabled' => 1 , 'visible' =>- 1 , 'notnull' => 1 , 'position' => 180 ),
2020-09-30 11:45:29 +02:00
'note_private' => array ( 'type' => 'text' , 'label' => 'NotePrivate' , 'enabled' => 1 , 'visible' => 3 , 'position' => 195 , 'searchall' => 1 ),
'note_public' => array ( 'type' => 'text' , 'label' => 'NotePublic' , 'enabled' => 1 , 'visible' => 3 , 'position' => 200 , 'searchall' => 1 ),
'default_lang' => array ( 'type' => 'varchar(6)' , 'label' => 'Default lang' , 'enabled' => 1 , 'visible' => 3 , 'position' => 205 ),
'canvas' => array ( 'type' => 'varchar(32)' , 'label' => 'Canvas' , 'enabled' => 1 , 'visible' => 3 , 'position' => 210 ),
2021-09-06 12:51:40 +02:00
'datec' => array ( 'type' => 'datetime' , 'label' => 'DateCreation' , 'enabled' => 1 , 'visible' =>- 1 , 'position' => 300 ),
'tms' => array ( 'type' => 'timestamp' , 'label' => 'DateModification' , 'enabled' => 1 , 'visible' =>- 1 , 'notnull' => 1 , 'position' => 305 ),
'fk_user_creat' => array ( 'type' => 'integer' , 'label' => 'UserAuthor' , 'enabled' => 1 , 'visible' => 3 , 'position' => 310 ),
'fk_user_modif' => array ( 'type' => 'integer' , 'label' => 'UserModif' , 'enabled' => 1 , 'visible' => 3 , 'position' => 315 ),
2020-09-29 14:59:16 +02:00
'statut' => array ( 'type' => 'tinyint(4)' , 'label' => 'Status' , 'enabled' => 1 , 'visible' => 1 , 'notnull' => 1 , 'position' => 500 ),
2020-09-30 11:45:29 +02:00
'import_key' => array ( 'type' => 'varchar(14)' , 'label' => 'ImportId' , 'enabled' => 1 , 'visible' =>- 1 , 'position' => 1000 ),
2019-12-20 11:14:16 +01:00
);
2019-12-03 11:17:29 +01:00
public $civility_id ; // In fact we store civility_code
2017-02-08 21:13:54 +01:00
public $civility_code ;
2019-09-05 13:38:38 +02:00
public $civility ;
2019-10-25 08:12:54 +02:00
2022-05-22 15:39:49 +02:00
/**
* @ var string The civilite code , not an integer
* @ deprecated
* @ see $civility_code
*/
public $civilite ;
2019-10-25 08:12:54 +02:00
/**
2020-11-05 14:48:41 +01:00
* @ var string Address
2019-10-25 08:12:54 +02:00
*/
2017-02-08 21:13:54 +01:00
public $address ;
2020-11-05 14:48:41 +01:00
/**
* @ var string zip code
*/
2017-02-08 21:13:54 +01:00
public $zip ;
2020-11-05 14:48:41 +01:00
/**
* @ var string Town
*/
2017-02-08 21:13:54 +01:00
public $town ;
2010-06-06 16:30:28 +02:00
2021-01-16 14:24:47 +01:00
/**
* @ var int // Id of department
*/
public $state_id ;
/**
* @ var string // Code of department
*/
public $state_code ;
/**
* @ var string // Label of department
*/
public $state ;
2010-06-06 16:30:28 +02:00
2020-10-31 14:32:18 +01:00
public $poste ; // Position
2013-11-27 15:19:24 +01:00
2021-01-16 14:24:47 +01:00
/**
* @ var int Thirdparty ID
*/
2021-10-05 13:09:32 +02:00
public $socid ; // both socid and fk_soc are used
public $fk_soc ; // both socid and fk_soc are used
2021-01-16 14:24:47 +01:00
/**
* @ var int 0 = inactive , 1 = active
*/
public $statut ;
2009-08-11 14:51:33 +02:00
2017-02-08 21:13:54 +01:00
public $code ;
2019-10-25 08:12:54 +02:00
2020-10-31 14:32:18 +01:00
/**
* Email
* @ var string
*/
2017-02-08 21:13:54 +01:00
public $email ;
2019-09-12 18:04:24 +02:00
2022-05-19 13:08:00 +02:00
/**
* URL
* @ var string
*/
public $url ;
2020-10-31 14:32:18 +01:00
/**
* Unsuscribe all : 1 = contact has globaly unsubscribe of all mass emailings
2019-10-25 08:12:54 +02:00
* @ var int
2020-10-31 14:32:18 +01:00
*/
2019-10-25 08:12:54 +02:00
public $no_email ;
2020-10-31 14:32:18 +01:00
/**
* @ var array array of socialnetworks
*/
public $socialnetworks ;
2019-09-12 18:04:24 +02:00
2020-10-31 14:32:18 +01:00
/**
* Skype username
* @ var string
* @ deprecated
*/
2017-02-08 21:13:54 +01:00
public $skype ;
2019-09-14 11:26:31 +02:00
/**
2020-10-31 14:32:18 +01:00
* Twitter username
* @ var string
* @ deprecated
*/
2019-10-30 20:07:50 +01:00
public $twitter ;
2019-09-14 11:26:31 +02:00
/**
2020-10-31 14:32:18 +01:00
* Facebook username
* @ var string
* @ deprecated
*/
2019-10-30 20:07:50 +01:00
public $facebook ;
2019-09-14 11:26:31 +02:00
/**
2020-10-31 14:32:18 +01:00
* Linkedin username
* @ var string
* @ deprecated
*/
public $linkedin ;
/**
* Jabber username
* @ var string
* @ deprecated
*/
2018-01-11 20:39:23 +01:00
public $jabberid ;
2019-09-14 11:26:31 +02:00
2020-11-05 14:48:41 +01:00
/**
* @ var string filename for photo
*/
2019-09-14 11:26:31 +02:00
public $photo ;
2020-11-05 14:48:41 +01:00
/**
* @ var string phone pro
*/
2017-02-08 21:13:54 +01:00
public $phone_pro ;
2020-11-05 14:48:41 +01:00
/**
* @ var string phone perso
*/
2017-02-08 21:13:54 +01:00
public $phone_perso ;
2020-11-05 14:48:41 +01:00
/**
* @ var string phone mobile
*/
2017-02-08 21:13:54 +01:00
public $phone_mobile ;
2020-11-05 14:48:41 +01:00
/**
* @ var string fax
*/
2018-01-11 20:39:23 +01:00
public $fax ;
2013-11-14 17:16:27 +01:00
2020-01-07 10:54:19 +01:00
/**
* Private or public
* @ var int
*/
2018-01-11 20:39:23 +01:00
public $priv ;
2013-10-27 02:33:03 +02:00
2017-02-08 21:13:54 +01:00
public $birthday ;
public $default_lang ;
2009-08-11 14:51:33 +02:00
2021-02-11 21:26:21 +01:00
/**
* @ var int Number of invoices for which he is contact
*/
public $ref_facturation ;
/**
* @ var int Number of contracts for which he is contact
*/
public $ref_contrat ;
/**
* @ var int Number of orders for which he is contact
*/
public $ref_commande ;
/**
* @ var int Number of proposals for which he is contact
*/
public $ref_propal ;
2006-02-25 00:16:35 +01:00
2021-01-16 14:24:47 +01:00
/**
* @ var int user ID
*/
2017-02-08 21:13:54 +01:00
public $user_id ;
2021-01-16 14:24:47 +01:00
/**
* @ var string user login
*/
2017-02-08 21:13:54 +01:00
public $user_login ;
2007-04-27 00:01:10 +02:00
2018-01-31 10:51:40 +01:00
// END MODULEBUILDER PROPERTIES
2020-10-31 14:32:18 +01:00
/**
* Old copy
* @ var Contact
*/
2019-12-03 11:17:29 +01:00
public $oldcopy ; // To contains a clone of this when we need to save old properties of object
2009-08-12 01:42:21 +02:00
2021-01-16 14:24:47 +01:00
/**
* @ var array roles
*/
2021-01-22 13:40:00 +01:00
public $roles ;
2019-09-02 14:47:32 +02:00
2020-04-27 17:35:14 +02:00
public $cacheprospectstatus = array ();
public $fk_prospectlevel ;
public $stcomm_id ;
public $statut_commercial ;
2021-01-16 14:24:47 +01:00
/**
* @ var string picto
*/
2020-04-27 17:35:14 +02:00
public $stcomm_picto ;
2007-04-27 00:01:10 +02:00
2022-05-19 13:08:00 +02:00
2009-08-11 14:51:33 +02:00
/**
2011-09-11 20:35:38 +02:00
* Constructor
*
2011-12-30 14:18:19 +01:00
* @ param DoliDB $db Database handler
2009-08-11 14:51:33 +02:00
*/
2019-02-25 00:56:48 +01:00
public function __construct ( $db )
2009-08-11 14:51:33 +02:00
{
2019-12-20 11:14:16 +01:00
global $conf , $langs ;
2011-12-30 14:18:19 +01:00
$this -> db = $db ;
2020-09-30 11:45:29 +02:00
$this -> statut = 1 ; // By default, status is enabled
2020-11-05 14:48:41 +01:00
if ( empty ( $conf -> global -> MAIN_SHOW_TECHNICAL_ID )) {
$this -> fields [ 'rowid' ][ 'visible' ] = 0 ;
}
if ( empty ( $conf -> mailing -> enabled )) {
$this -> fields [ 'no_email' ][ 'enabled' ] = 0 ;
}
2020-09-30 11:45:29 +02:00
// typical ['s.nom'] is used for third-parties
if ( empty ( $conf -> global -> SOCIETE_DISABLE_CONTACTS )) {
$this -> fields [ 'fk_soc' ][ 'enabled' ] = 0 ;
$this -> fields [ 'fk_soc' ][ 'searchall' ] = 0 ;
}
2019-12-20 11:14:16 +01:00
2020-08-02 22:30:23 +02:00
if ( empty ( $conf -> global -> THIRDPARTY_ENABLE_PROSPECTION_ON_ALTERNATIVE_ADRESSES )) { // Default behaviour
2020-09-30 11:45:29 +02:00
$this -> field [ 'fk_stcommcontact' ][ 'enabled' ] = 0 ;
$this -> field [ 'fk_prospectcontactlevel' ][ 'enabled' ] = 0 ;
2020-08-02 22:30:23 +02:00
}
2019-12-20 11:14:16 +01:00
// Unset fields that are disabled
2020-11-05 14:48:41 +01:00
foreach ( $this -> fields as $key => $val ) {
if ( isset ( $val [ 'enabled' ]) && empty ( $val [ 'enabled' ])) {
2019-12-20 11:14:16 +01:00
unset ( $this -> fields [ $key ]);
}
}
// Translate some data of arrayofkeyval
/* if ( is_object ( $langs ))
{
foreach ( $this -> fields as $key => $val )
{
2020-10-30 05:45:36 +01:00
if ( ! empty ( $val [ 'arrayofkeyval' ]) && is_array ( $val [ 'arrayofkeyval' ]))
2019-12-20 11:14:16 +01:00
{
foreach ( $val [ 'arrayofkeyval' ] as $key2 => $val2 )
{
$this -> fields [ $key ][ 'arrayofkeyval' ][ $key2 ] = $langs -> trans ( $val2 );
}
}
}
} */
2009-08-11 14:51:33 +02:00
}
2017-07-13 23:52:02 +02:00
2020-10-31 14:32:18 +01:00
// phpcs:disable PEAR.NamingConventions.ValidFunctionName.ScopeNotCamelCaps
2016-04-23 13:06:46 +02:00
/**
* Load indicators into this -> nb for board
*
* @ return int < 0 if KO , > 0 if OK
*/
2019-02-25 00:56:48 +01:00
public function load_state_board ()
2016-04-23 13:06:46 +02:00
{
2020-10-31 14:32:18 +01:00
// phpcs:enable
2022-03-22 15:51:30 +01:00
global $user , $hookmanager ;
2017-07-13 23:52:02 +02:00
2019-12-03 11:17:29 +01:00
$this -> nb = array ();
2016-04-23 13:06:46 +02:00
$clause = " WHERE " ;
2017-07-13 23:52:02 +02:00
2016-04-23 13:06:46 +02:00
$sql = " SELECT count(sp.rowid) as nb " ;
2019-12-03 11:17:29 +01:00
$sql .= " FROM " . MAIN_DB_PREFIX . " socpeople as sp " ;
2021-10-22 22:15:59 +02:00
if ( empty ( $user -> rights -> societe -> client -> voir ) && ! $user -> socid ) {
2020-10-31 14:32:18 +01:00
$sql .= " , " . MAIN_DB_PREFIX . " societe as s " ;
$sql .= " , " . MAIN_DB_PREFIX . " societe_commerciaux as sc " ;
2021-08-23 17:41:11 +02:00
$sql .= " WHERE sp.fk_soc = s.rowid AND s.rowid = sc.fk_soc AND sc.fk_user = " . (( int ) $user -> id );
2016-04-23 13:06:46 +02:00
$clause = " AND " ;
}
2021-08-28 00:55:51 +02:00
$sql .= " " . $clause . " sp.entity IN ( " . getEntity ( $this -> element ) . " ) " ;
$sql .= " AND (sp.priv='0' OR (sp.priv='1' AND sp.fk_user_creat = " . (( int ) $user -> id ) . " )) " ;
2021-01-16 14:24:47 +01:00
if ( $user -> socid > 0 ) {
2021-08-23 17:41:11 +02:00
$sql .= " AND sp.fk_soc = " . (( int ) $user -> socid );
2021-01-16 14:24:47 +01:00
}
2022-03-22 15:51:30 +01:00
// Add where from hooks
if ( is_object ( $hookmanager )) {
$parameters = array ();
$reshook = $hookmanager -> executeHooks ( 'printFieldListWhere' , $parameters , $this ); // Note that $action and $object may have been modified by hook
$sql .= $hookmanager -> resPrint ;
}
2017-07-13 23:52:02 +02:00
2019-12-03 11:17:29 +01:00
$resql = $this -> db -> query ( $sql );
2021-01-16 14:24:47 +01:00
if ( $resql ) {
while ( $obj = $this -> db -> fetch_object ( $resql )) {
2019-12-03 11:17:29 +01:00
$this -> nb [ " contacts " ] = $obj -> nb ;
2016-04-23 13:06:46 +02:00
}
$this -> db -> free ( $resql );
return 1 ;
2020-05-21 15:05:19 +02:00
} else {
2016-04-23 13:06:46 +02:00
dol_print_error ( $this -> db );
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> lasterror ();
2016-04-23 13:06:46 +02:00
return - 1 ;
}
}
2009-08-11 14:51:33 +02:00
/**
2011-09-11 20:35:38 +02:00
* Add a contact into database
*
* @ param User $user Object user that create
* @ return int < 0 if KO , > 0 if OK
2009-08-11 14:51:33 +02:00
*/
2019-02-25 00:56:48 +01:00
public function create ( $user )
2009-08-11 14:51:33 +02:00
{
global $conf , $langs ;
2019-04-11 18:04:18 +02:00
2019-11-08 15:51:54 +01:00
$error = 0 ;
$now = dol_now ();
2010-06-06 16:30:28 +02:00
2010-11-19 22:24:48 +01:00
$this -> db -> begin ();
2008-04-10 01:07:13 +02:00
// Clean parameters
2019-11-08 15:51:54 +01:00
$this -> lastname = $this -> lastname ? trim ( $this -> lastname ) : trim ( $this -> name );
2020-10-31 14:32:18 +01:00
$this -> firstname = trim ( $this -> firstname );
2020-10-28 20:50:33 +01:00
$this -> setUpperOrLowerCase ();
2021-02-11 21:26:21 +01:00
if ( empty ( $this -> socid )) {
$this -> socid = 0 ;
}
if ( empty ( $this -> priv )) {
$this -> priv = 0 ;
}
if ( empty ( $this -> statut )) {
$this -> statut = 0 ; // This is to convert '' into '0' to avoid bad sql request
}
2006-02-25 00:16:35 +01:00
2019-11-08 15:51:54 +01:00
$this -> entity = (( isset ( $this -> entity ) && is_numeric ( $this -> entity )) ? $this -> entity : $conf -> entity );
2018-01-11 20:39:23 +01:00
2011-04-17 20:14:29 +02:00
$sql = " INSERT INTO " . MAIN_DB_PREFIX . " socpeople ( " ;
2019-11-08 15:51:54 +01:00
$sql .= " datec " ;
$sql .= " , fk_soc " ;
2020-10-31 14:32:18 +01:00
$sql .= " , lastname " ;
$sql .= " , firstname " ;
$sql .= " , fk_user_creat " ;
2019-11-08 15:51:54 +01:00
$sql .= " , priv " ;
2020-10-31 14:32:18 +01:00
$sql .= " , fk_stcommcontact " ;
2019-11-08 15:51:54 +01:00
$sql .= " , statut " ;
$sql .= " , canvas " ;
$sql .= " , entity " ;
$sql .= " , ref_ext " ;
$sql .= " , import_key " ;
$sql .= " ) VALUES ( " ;
$sql .= " ' " . $this -> db -> idate ( $now ) . " ', " ;
2021-01-16 14:24:47 +01:00
if ( $this -> socid > 0 ) {
2021-06-14 13:51:09 +02:00
$sql .= " " . (( int ) $this -> socid ) . " , " ;
2021-01-16 14:24:47 +01:00
} else {
$sql .= " null, " ;
}
2019-11-08 15:51:54 +01:00
$sql .= " ' " . $this -> db -> escape ( $this -> lastname ) . " ', " ;
2020-10-31 18:51:30 +01:00
$sql .= " ' " . $this -> db -> escape ( $this -> firstname ) . " ', " ;
2021-06-14 14:15:32 +02:00
$sql .= " " . ( $user -> id > 0 ? (( int ) $user -> id ) : " null " ) . " , " ;
2021-06-14 13:51:09 +02:00
$sql .= " " . (( int ) $this -> priv ) . " , " ;
2020-10-31 14:32:18 +01:00
$sql .= " 0, " ;
2021-06-14 13:51:09 +02:00
$sql .= " " . (( int ) $this -> statut ) . " , " ;
2020-10-31 18:51:30 +01:00
$sql .= " " . ( ! empty ( $this -> canvas ) ? " ' " . $this -> db -> escape ( $this -> canvas ) . " ' " : " null " ) . " , " ;
2021-06-14 13:51:09 +02:00
$sql .= " " . (( int ) $this -> entity ) . " , " ;
2020-10-31 18:51:30 +01:00
$sql .= " ' " . $this -> db -> escape ( $this -> ref_ext ) . " ', " ;
$sql .= " " . ( ! empty ( $this -> import_key ) ? " ' " . $this -> db -> escape ( $this -> import_key ) . " ' " : " null " );
2019-11-08 15:51:54 +01:00
$sql .= " ) " ;
2009-08-11 14:51:33 +02:00
2014-06-12 11:31:53 +02:00
dol_syslog ( get_class ( $this ) . " ::create " , LOG_DEBUG );
2019-11-08 15:51:54 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( $resql ) {
2009-08-11 14:51:33 +02:00
$this -> id = $this -> db -> last_insert_id ( MAIN_DB_PREFIX . " socpeople " );
2021-02-23 21:16:15 +01:00
if ( ! $error ) {
2020-10-31 14:32:18 +01:00
$result = $this -> update ( $this -> id , $user , 1 , 'add' ); // This include updateRoles(), ...
2021-02-23 21:16:15 +01:00
if ( $result < 0 ) {
2020-10-31 14:32:18 +01:00
$error ++ ;
$this -> error = $this -> db -> lasterror ();
}
}
2021-02-23 21:16:15 +01:00
if ( ! $error ) {
2020-10-31 14:32:18 +01:00
$result = $this -> update_perso ( $this -> id , $user , 1 ); // TODO Remove function update_perso, should be same than update
2021-02-23 21:16:15 +01:00
if ( $result < 0 ) {
2020-10-31 14:32:18 +01:00
$error ++ ;
$this -> error = $this -> db -> lasterror ();
}
}
2021-02-23 21:16:15 +01:00
if ( ! $error ) {
2020-10-31 14:32:18 +01:00
// Call trigger
$result = $this -> call_trigger ( 'CONTACT_CREATE' , $user );
2021-02-23 21:16:15 +01:00
if ( $result < 0 ) {
$error ++ ;
}
2020-10-31 14:32:18 +01:00
// End call triggers
2009-08-11 14:51:33 +02:00
}
2021-02-23 21:16:15 +01:00
if ( ! $error ) {
2020-10-31 14:32:18 +01:00
$this -> db -> commit ();
return $this -> id ;
} else {
$this -> db -> rollback ();
dol_syslog ( get_class ( $this ) . " ::create " . $this -> error , LOG_ERR );
return - 2 ;
}
2020-05-21 15:05:19 +02:00
} else {
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> lasterror ();
2010-11-19 22:24:48 +01:00
$this -> db -> rollback ();
2011-12-30 14:18:19 +01:00
dol_syslog ( get_class ( $this ) . " ::create " . $this -> error , LOG_ERR );
2009-08-11 14:51:33 +02:00
return - 1 ;
}
}
2010-02-21 14:08:02 +01:00
/**
2010-11-19 22:24:48 +01:00
* Update informations into database
2011-09-16 19:57:09 +02:00
*
* @ param int $id Id of contact / address to update
* @ param User $user Objet user making change
2012-11-10 16:08:26 +01:00
* @ param int $notrigger 0 = no , 1 = yes
* @ param string $action Current action for hookmanager
2017-12-19 16:16:31 +01:00
* @ param int $nosyncuser No sync linked user ( external users and contacts are linked )
2011-09-16 19:57:09 +02:00
* @ return int < 0 if KO , > 0 if OK
2009-08-11 14:51:33 +02:00
*/
2019-02-25 00:56:48 +01:00
public function update ( $id , $user = null , $notrigger = 0 , $action = 'update' , $nosyncuser = 0 )
2009-08-11 14:51:33 +02:00
{
2013-01-25 19:12:54 +01:00
global $conf , $langs , $hookmanager ;
2009-08-11 14:51:33 +02:00
2019-11-08 15:51:54 +01:00
$error = 0 ;
2009-08-11 22:16:58 +02:00
2009-08-11 14:51:33 +02:00
$this -> id = $id ;
2019-11-08 15:51:54 +01:00
$this -> entity = (( isset ( $this -> entity ) && is_numeric ( $this -> entity )) ? $this -> entity : $conf -> entity );
2018-07-08 12:11:22 +02:00
2011-12-30 14:18:19 +01:00
// Clean parameters
2021-06-17 18:01:31 +02:00
$this -> ref_ext = trim ( $this -> ref_ext );
2019-11-08 15:51:54 +01:00
$this -> lastname = trim ( $this -> lastname ) ? trim ( $this -> lastname ) : trim ( $this -> lastname );
$this -> firstname = trim ( $this -> firstname );
$this -> email = trim ( $this -> email );
$this -> phone_pro = trim ( $this -> phone_pro );
$this -> phone_perso = trim ( $this -> phone_perso );
$this -> phone_mobile = trim ( $this -> phone_mobile );
$this -> photo = trim ( $this -> photo );
$this -> fax = trim ( $this -> fax );
2020-10-28 20:50:33 +01:00
$this -> zip = ( empty ( $this -> zip ) ? '' : trim ( $this -> zip ));
$this -> town = ( empty ( $this -> town ) ? '' : trim ( $this -> town ));
$this -> setUpperOrLowerCase ();
2019-11-08 15:51:54 +01:00
$this -> country_id = ( $this -> country_id > 0 ? $this -> country_id : $this -> country_id );
2021-02-23 21:16:15 +01:00
if ( empty ( $this -> statut )) {
$this -> statut = 0 ;
}
if ( empty ( $this -> civility_code ) && ! is_numeric ( $this -> civility_id )) {
$this -> civility_code = $this -> civility_id ; // For backward compatibility
}
2009-08-11 22:16:58 +02:00
$this -> db -> begin ();
2021-06-19 14:22:41 +02:00
$sql = " UPDATE " . MAIN_DB_PREFIX . " socpeople SET " ;
2021-02-23 21:16:15 +01:00
if ( $this -> socid > 0 ) {
2021-06-19 14:22:41 +02:00
$sql .= " fk_soc = " . (( int ) $this -> socid ) . " , " ;
2021-02-23 21:16:15 +01:00
} elseif ( $this -> socid == - 1 ) {
2021-06-19 14:22:41 +02:00
$sql .= " fk_soc = NULL, " ;
2021-02-23 21:16:15 +01:00
}
2021-06-19 14:22:41 +02:00
$sql .= " civility=' " . $this -> db -> escape ( $this -> civility_code ) . " ' " ;
2013-02-23 15:58:26 +01:00
$sql .= " , lastname=' " . $this -> db -> escape ( $this -> lastname ) . " ' " ;
2011-02-24 19:11:12 +01:00
$sql .= " , firstname=' " . $this -> db -> escape ( $this -> firstname ) . " ' " ;
$sql .= " , address=' " . $this -> db -> escape ( $this -> address ) . " ' " ;
2013-02-24 17:08:52 +01:00
$sql .= " , zip=' " . $this -> db -> escape ( $this -> zip ) . " ' " ;
2013-02-22 16:53:50 +01:00
$sql .= " , town=' " . $this -> db -> escape ( $this -> town ) . " ' " ;
2021-06-19 14:22:41 +02:00
$sql .= " , ref_ext = " . ( ! empty ( $this -> ref_ext ) ? " ' " . $this -> db -> escape ( $this -> ref_ext ) . " ' " : " NULL " );
2019-11-08 15:51:54 +01:00
$sql .= " , fk_pays= " . ( $this -> country_id > 0 ? $this -> country_id : 'NULL' );
$sql .= " , fk_departement= " . ( $this -> state_id > 0 ? $this -> state_id : 'NULL' );
2011-02-24 19:11:12 +01:00
$sql .= " , poste=' " . $this -> db -> escape ( $this -> poste ) . " ' " ;
$sql .= " , fax=' " . $this -> db -> escape ( $this -> fax ) . " ' " ;
$sql .= " , email=' " . $this -> db -> escape ( $this -> email ) . " ' " ;
2020-10-31 14:32:18 +01:00
$sql .= " , socialnetworks = ' " . $this -> db -> escape ( json_encode ( $this -> socialnetworks )) . " ' " ;
2015-10-04 17:25:46 +02:00
$sql .= " , photo=' " . $this -> db -> escape ( $this -> photo ) . " ' " ;
2018-04-11 14:43:16 +02:00
$sql .= " , birthday= " . ( $this -> birthday ? " ' " . $this -> db -> idate ( $this -> birthday ) . " ' " : " null " );
2021-06-19 14:22:41 +02:00
$sql .= " , note_private = " . ( isset ( $this -> note_private ) ? " ' " . $this -> db -> escape ( $this -> note_private ) . " ' " : " NULL " );
$sql .= " , note_public = " . ( isset ( $this -> note_public ) ? " ' " . $this -> db -> escape ( $this -> note_public ) . " ' " : " NULL " );
$sql .= " , phone = " . ( isset ( $this -> phone_pro ) ? " ' " . $this -> db -> escape ( $this -> phone_pro ) . " ' " : " NULL " );
$sql .= " , phone_perso = " . ( isset ( $this -> phone_perso ) ? " ' " . $this -> db -> escape ( $this -> phone_perso ) . " ' " : " NULL " );
$sql .= " , phone_mobile = " . ( isset ( $this -> phone_mobile ) ? " ' " . $this -> db -> escape ( $this -> phone_mobile ) . " ' " : " NULL " );
2017-05-12 16:55:11 +02:00
$sql .= " , priv = ' " . $this -> db -> escape ( $this -> priv ) . " ' " ;
2020-04-27 17:35:14 +02:00
$sql .= " , fk_prospectcontactlevel = ' " . $this -> db -> escape ( $this -> fk_prospectlevel ) . " ' " ;
2021-02-23 21:16:15 +01:00
if ( isset ( $this -> stcomm_id )) {
2020-04-27 17:35:14 +02:00
$sql .= " , fk_stcommcontact = " . ( $this -> stcomm_id > 0 || $this -> stcomm_id == - 1 ? $this -> stcomm_id : " 0 " );
}
2021-06-09 15:36:47 +02:00
$sql .= " , statut = " . (( int ) $this -> statut );
2019-12-03 11:17:29 +01:00
$sql .= " , fk_user_modif= " . ( $user -> id > 0 ? " ' " . $this -> db -> escape ( $user -> id ) . " ' " : " NULL " );
$sql .= " , default_lang= " . ( $this -> default_lang ? " ' " . $this -> db -> escape ( $this -> default_lang ) . " ' " : " NULL " );
2021-06-09 15:36:47 +02:00
$sql .= " , entity = " . (( int ) $this -> entity );
2021-08-27 18:18:50 +02:00
$sql .= " WHERE rowid = " . (( int ) $id );
2009-08-11 14:51:33 +02:00
2014-06-12 11:31:53 +02:00
dol_syslog ( get_class ( $this ) . " ::update " , LOG_DEBUG );
2009-08-11 14:51:33 +02:00
$result = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( $result ) {
2020-10-31 14:32:18 +01:00
unset ( $this -> country_code );
unset ( $this -> country );
unset ( $this -> state_code );
unset ( $this -> state );
$action = 'update' ;
// Actions on extra fields
2021-02-23 21:16:15 +01:00
if ( ! $error ) {
2020-10-31 14:32:18 +01:00
$result = $this -> insertExtraFields ();
2021-02-23 21:16:15 +01:00
if ( $result < 0 ) {
2020-10-31 14:32:18 +01:00
$error ++ ;
}
}
2012-09-17 01:39:30 +02:00
2019-11-08 15:51:54 +01:00
if ( ! $error ) {
$result = $this -> updateRoles ();
2021-02-23 21:16:15 +01:00
if ( $result < 0 ) {
2019-09-02 22:01:48 +02:00
$error ++ ;
}
}
2021-02-23 21:16:15 +01:00
if ( ! $error && $this -> user_id > 0 ) {
2019-10-22 15:21:41 +02:00
// If contact is linked to a user
2017-12-19 16:16:31 +01:00
$tmpobj = new User ( $this -> db );
$tmpobj -> fetch ( $this -> user_id );
$usermustbemodified = 0 ;
2021-02-11 21:26:21 +01:00
if ( $tmpobj -> office_phone != $this -> phone_pro ) {
2017-12-19 16:16:31 +01:00
$tmpobj -> office_phone = $this -> phone_pro ;
$usermustbemodified ++ ;
}
2021-02-11 21:26:21 +01:00
if ( $tmpobj -> office_fax != $this -> fax ) {
2017-12-19 16:16:31 +01:00
$tmpobj -> office_fax = $this -> fax ;
$usermustbemodified ++ ;
}
2021-02-11 21:26:21 +01:00
if ( $tmpobj -> address != $this -> address ) {
2017-12-19 16:16:31 +01:00
$tmpobj -> address = $this -> address ;
$usermustbemodified ++ ;
}
2021-02-11 21:26:21 +01:00
if ( $tmpobj -> town != $this -> town ) {
2017-12-19 16:16:31 +01:00
$tmpobj -> town = $this -> town ;
$usermustbemodified ++ ;
}
2021-02-11 21:26:21 +01:00
if ( $tmpobj -> zip != $this -> zip ) {
2017-12-19 16:16:31 +01:00
$tmpobj -> zip = $this -> zip ;
$usermustbemodified ++ ;
}
2021-02-11 21:26:21 +01:00
if ( $tmpobj -> zip != $this -> zip ) {
2019-11-08 15:51:54 +01:00
$tmpobj -> state_id = $this -> state_id ;
2017-12-19 16:16:31 +01:00
$usermustbemodified ++ ;
}
2021-02-11 21:26:21 +01:00
if ( $tmpobj -> country_id != $this -> country_id ) {
2017-12-19 16:16:31 +01:00
$tmpobj -> country_id = $this -> country_id ;
$usermustbemodified ++ ;
}
2021-02-11 21:26:21 +01:00
if ( $tmpobj -> email != $this -> email ) {
2017-12-19 16:16:31 +01:00
$tmpobj -> email = $this -> email ;
$usermustbemodified ++ ;
}
2021-02-11 21:26:21 +01:00
if ( ! empty ( array_diff ( $tmpobj -> socialnetworks , $this -> socialnetworks ))) {
2019-09-14 11:26:31 +02:00
$tmpobj -> socialnetworks = $this -> socialnetworks ;
2018-09-26 16:55:46 +02:00
$usermustbemodified ++ ;
}
2021-02-11 21:26:21 +01:00
// if ($tmpobj->skype != $this->skype) {
2019-09-14 11:26:31 +02:00
// $tmpobj->skype = $this->skype;
// $usermustbemodified++;
// }
2021-02-11 21:26:21 +01:00
// if ($tmpobj->twitter != $this->twitter) {
2019-09-14 11:26:31 +02:00
// $tmpobj->twitter = $this->twitter;
// $usermustbemodified++;
// }
2021-02-11 21:26:21 +01:00
// if ($tmpobj->facebook != $this->facebook) {
2019-09-14 11:26:31 +02:00
// $tmpobj->facebook = $this->facebook;
// $usermustbemodified++;
// }
2021-02-11 21:26:21 +01:00
// if ($tmpobj->linkedin != $this->linkedin) {
2019-09-14 11:26:31 +02:00
// $tmpobj->linkedin = $this->linkedin;
// $usermustbemodified++;
// }
2021-02-11 21:26:21 +01:00
if ( $usermustbemodified ) {
2019-09-14 11:26:31 +02:00
$result = $tmpobj -> update ( $user , 0 , 1 , 1 , 1 );
2021-02-23 21:16:15 +01:00
if ( $result < 0 ) {
$error ++ ;
}
2017-12-19 16:16:31 +01:00
}
}
2021-02-11 21:26:21 +01:00
if ( ! $error && ! $notrigger ) {
2017-12-19 16:16:31 +01:00
// Call trigger
2019-12-03 11:17:29 +01:00
$result = $this -> call_trigger ( 'CONTACT_MODIFY' , $user );
2021-02-23 21:16:15 +01:00
if ( $result < 0 ) {
$error ++ ;
}
2017-12-19 16:16:31 +01:00
// End call triggers
2009-08-11 22:16:58 +02:00
}
2021-02-11 21:26:21 +01:00
if ( ! $error ) {
2009-08-11 22:16:58 +02:00
$this -> db -> commit ();
return 1 ;
2020-05-21 15:05:19 +02:00
} else {
2019-01-27 11:55:16 +01:00
dol_syslog ( get_class ( $this ) . " ::update Error " . $this -> error , LOG_ERR );
2009-08-11 22:16:58 +02:00
$this -> db -> rollback ();
return - $error ;
}
2020-05-21 15:05:19 +02:00
} else {
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> lasterror () . ' sql=' . $sql ;
2020-10-31 14:32:18 +01:00
$this -> db -> rollback ();
2009-08-11 14:51:33 +02:00
return - 1 ;
}
}
2009-01-19 23:41:26 +01:00
2020-10-31 14:32:18 +01:00
// phpcs:disable PEAR.NamingConventions.ValidFunctionName.ScopeNotCamelCaps
// phpcs:disable PEAR.NamingConventions.ValidFunctionName.PublicUnderscore
2009-08-11 14:51:33 +02:00
/**
2011-09-16 19:57:09 +02:00
* Retourne chaine DN complete dans l 'annuaire LDAP pour l' objet
*
* @ param array $info Info string loaded by _load_ldap_info
* @ param int $mode 0 = Return full DN ( uid = qqq , ou = xxx , dc = aaa , dc = bbb )
* 1 = Return DN without key inside ( ou = xxx , dc = aaa , dc = bbb )
* 2 = Return key only ( uid = qqq )
* @ return string DN
2009-08-11 14:51:33 +02:00
*/
2019-07-13 11:21:07 +02:00
public function _load_ldap_dn ( $info , $mode = 0 )
2006-11-19 02:46:32 +01:00
{
2020-10-31 14:32:18 +01:00
// phpcs:enable
2006-11-21 23:51:05 +01:00
global $conf ;
2019-11-08 15:51:54 +01:00
$dn = '' ;
2021-02-11 21:26:21 +01:00
if ( $mode == 0 ) {
$dn = $conf -> global -> LDAP_KEY_CONTACTS . " = " . $info [ $conf -> global -> LDAP_KEY_CONTACTS ] . " , " . $conf -> global -> LDAP_CONTACT_DN ;
} elseif ( $mode == 1 ) {
$dn = $conf -> global -> LDAP_CONTACT_DN ;
} elseif ( $mode == 2 ) {
$dn = $conf -> global -> LDAP_KEY_CONTACTS . " = " . $info [ $conf -> global -> LDAP_KEY_CONTACTS ];
}
2006-11-21 23:51:05 +01:00
return $dn ;
}
2006-11-19 02:46:32 +01:00
2006-11-20 02:13:13 +01:00
2020-10-31 14:32:18 +01:00
// phpcs:disable PEAR.NamingConventions.ValidFunctionName.ScopeNotCamelCaps
// phpcs:disable PEAR.NamingConventions.ValidFunctionName.PublicUnderscore
2009-08-11 14:51:33 +02:00
/**
2011-09-16 19:57:09 +02:00
* Initialise tableau info ( tableau des attributs LDAP )
*
* @ return array Tableau info des attributs
2009-08-11 14:51:33 +02:00
*/
2019-06-18 20:01:28 +02:00
public function _load_ldap_info ()
2006-11-20 02:13:13 +01:00
{
2020-10-31 14:32:18 +01:00
// phpcs:enable
2018-09-16 19:19:45 +02:00
global $conf , $langs ;
2006-11-20 02:13:13 +01:00
2020-10-31 14:32:18 +01:00
$info = array ();
2017-07-13 23:52:02 +02:00
2020-10-31 14:32:18 +01:00
// Object classes
2019-11-08 15:51:54 +01:00
$info [ " objectclass " ] = explode ( ',' , $conf -> global -> LDAP_CONTACT_OBJECT_CLASS );
2009-01-19 23:41:26 +01:00
2019-11-08 15:51:54 +01:00
$this -> fullname = $this -> getFullName ( $langs );
2010-07-18 12:39:07 +02:00
// Fields
2021-02-23 21:16:15 +01:00
if ( $this -> fullname && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_FULLNAME )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_FULLNAME ] = $this -> fullname ;
}
if ( $this -> lastname && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_NAME )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_NAME ] = $this -> lastname ;
}
if ( $this -> firstname && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_FIRSTNAME )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_FIRSTNAME ] = $this -> firstname ;
}
2006-11-21 23:51:05 +01:00
2021-02-23 21:16:15 +01:00
if ( $this -> poste ) {
$info [ " title " ] = $this -> poste ;
}
2021-01-16 14:24:47 +01:00
if ( $this -> socid > 0 ) {
2006-11-20 02:13:13 +01:00
$soc = new Societe ( $this -> db );
$soc -> fetch ( $this -> socid );
2014-10-04 17:20:17 +02:00
$info [ $conf -> global -> LDAP_CONTACT_FIELD_COMPANY ] = $soc -> name ;
2021-02-23 21:16:15 +01:00
if ( $soc -> client == 1 ) {
$info [ " businessCategory " ] = " Customers " ;
}
if ( $soc -> client == 2 ) {
$info [ " businessCategory " ] = " Prospects " ;
}
if ( $soc -> fournisseur == 1 ) {
$info [ " businessCategory " ] = " Suppliers " ;
}
}
if ( $this -> address && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_ADDRESS )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_ADDRESS ] = $this -> address ;
}
if ( $this -> zip && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_ZIP )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_ZIP ] = $this -> zip ;
}
if ( $this -> town && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_TOWN )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_TOWN ] = $this -> town ;
}
if ( $this -> country_code && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_COUNTRY )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_COUNTRY ] = $this -> country_code ;
}
if ( $this -> phone_pro && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_PHONE )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_PHONE ] = $this -> phone_pro ;
}
if ( $this -> phone_perso && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_HOMEPHONE )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_HOMEPHONE ] = $this -> phone_perso ;
}
if ( $this -> phone_mobile && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_MOBILE )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_MOBILE ] = $this -> phone_mobile ;
}
if ( $this -> fax && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_FAX )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_FAX ] = $this -> fax ;
}
if ( $this -> skype && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_SKYPE )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_SKYPE ] = $this -> skype ;
}
if ( $this -> note_private && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_DESCRIPTION )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_DESCRIPTION ] = dol_string_nohtmltag ( $this -> note_private , 2 );
}
if ( $this -> email && ! empty ( $conf -> global -> LDAP_CONTACT_FIELD_MAIL )) {
$info [ $conf -> global -> LDAP_CONTACT_FIELD_MAIL ] = $this -> email ;
}
if ( $conf -> global -> LDAP_SERVER_TYPE == 'egroupware' ) {
2006-11-20 02:13:13 +01:00
$info [ " objectclass " ][ 4 ] = " phpgwContact " ; // compatibilite egroupware
$info [ 'uidnumber' ] = $this -> id ;
2019-11-08 15:51:54 +01:00
$info [ 'phpgwTz' ] = 0 ;
2006-11-20 02:13:13 +01:00
$info [ 'phpgwMailType' ] = 'INTERNET' ;
$info [ 'phpgwMailHomeType' ] = 'INTERNET' ;
$info [ " phpgwContactTypeId " ] = 'n' ;
$info [ " phpgwContactCatId " ] = 0 ;
$info [ " phpgwContactAccess " ] = " public " ;
2021-01-16 14:24:47 +01:00
if ( dol_strlen ( $this -> egroupware_id ) == 0 ) {
2006-11-20 02:13:13 +01:00
$this -> egroupware_id = 1 ;
}
$info [ " phpgwContactOwner " ] = $this -> egroupware_id ;
2021-02-23 21:16:15 +01:00
if ( $this -> email ) {
$info [ " rfc822Mailbox " ] = $this -> email ;
}
if ( $this -> phone_mobile ) {
$info [ " phpgwCellTelephoneNumber " ] = $this -> phone_mobile ;
}
2006-11-20 02:13:13 +01:00
}
2009-01-19 23:41:26 +01:00
2006-11-20 02:13:13 +01:00
return $info ;
}
2009-01-19 23:41:26 +01:00
2020-10-31 14:32:18 +01:00
// phpcs:disable PEAR.NamingConventions.ValidFunctionName.ScopeNotCamelCaps
2010-11-19 22:24:48 +01:00
/**
2011-09-16 19:57:09 +02:00
* Update field alert birthday
*
* @ param int $id Id of contact
* @ param User $user User asking to change alert or birthday
2016-08-02 16:55:32 +02:00
* @ param int $notrigger 0 = no , 1 = yes
2020-10-31 14:32:18 +01:00
* @ return int < 0 if KO , >= 0 if OK
2009-08-11 14:51:33 +02:00
*/
2019-02-25 00:56:48 +01:00
public function update_perso ( $id , $user = null , $notrigger = 0 )
2006-11-18 22:59:10 +01:00
{
2020-10-31 14:32:18 +01:00
// phpcs:enable
$error = 0 ;
$result = false ;
2010-11-19 22:24:48 +01:00
2020-10-31 14:32:18 +01:00
$this -> db -> begin ();
2017-07-13 23:52:02 +02:00
2006-11-21 23:51:05 +01:00
// Mis a jour contact
2012-02-11 08:03:26 +01:00
$sql = " UPDATE " . MAIN_DB_PREFIX . " socpeople SET " ;
2021-08-27 18:18:50 +02:00
$sql .= " birthday = " . ( $this -> birthday ? " ' " . $this -> db -> idate ( $this -> birthday ) . " ' " : " null " );
2019-11-08 15:51:54 +01:00
$sql .= " , photo = " . ( $this -> photo ? " ' " . $this -> db -> escape ( $this -> photo ) . " ' " : " null " );
2021-02-23 21:16:15 +01:00
if ( $user ) {
2021-08-27 18:18:50 +02:00
$sql .= " , fk_user_modif = " . (( int ) $user -> id );
2021-02-23 21:16:15 +01:00
}
2021-08-27 18:18:50 +02:00
$sql .= " WHERE rowid = " . (( int ) $id );
2012-02-11 08:03:26 +01:00
2014-06-12 11:31:53 +02:00
dol_syslog ( get_class ( $this ) . " ::update_perso this->birthday= " . $this -> birthday . " - " , LOG_DEBUG );
2007-01-16 23:02:36 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( ! $resql ) {
2018-04-11 14:38:56 +02:00
$error ++ ;
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> lasterror ();
2006-11-21 23:51:05 +01:00
}
2009-01-19 23:41:26 +01:00
2021-06-28 11:03:22 +02:00
if ( $user ) {
2021-06-29 15:52:39 +02:00
// Update birthday alert
if ( ! empty ( $this -> birthday_alert )) {
2021-06-28 11:03:22 +02:00
//check existing
2021-06-29 15:52:39 +02:00
$sql_check = " SELECT rowid FROM " . MAIN_DB_PREFIX . " user_alert WHERE type = 1 AND fk_contact = " . (( int ) $id ) . " AND fk_user = " . (( int ) $user -> id );
2021-06-28 11:03:22 +02:00
$result_check = $this -> db -> query ( $sql_check );
if ( ! $result_check || ( $this -> db -> num_rows ( $result_check ) < 1 )) {
//insert
2021-06-29 15:52:39 +02:00
$sql = " INSERT INTO " . MAIN_DB_PREFIX . " user_alert(type, fk_contact, fk_user) " ;
$sql .= " VALUES (1, " . (( int ) $id ) . " , " . (( int ) $user -> id ) . " ) " ;
2021-06-28 11:03:22 +02:00
$result = $this -> db -> query ( $sql );
if ( ! $result ) {
$error ++ ;
$this -> error = $this -> db -> lasterror ();
}
} else {
$result = true ;
}
} else {
$sql = " DELETE FROM " . MAIN_DB_PREFIX . " user_alert " ;
2021-06-29 15:52:39 +02:00
$sql .= " WHERE type=1 AND fk_contact= " . (( int ) $id ) . " AND fk_user= " . (( int ) $user -> id );
2007-01-14 15:50:35 +01:00
$result = $this -> db -> query ( $sql );
2020-12-04 12:01:41 +01:00
if ( ! $result ) {
2020-10-31 14:32:18 +01:00
$error ++ ;
$this -> error = $this -> db -> lasterror ();
2007-01-14 15:50:35 +01:00
}
}
2006-11-18 22:59:10 +01:00
}
2010-11-19 22:24:48 +01:00
2020-12-04 12:01:41 +01:00
if ( ! $error && ! $notrigger ) {
2020-10-31 14:32:18 +01:00
// Call trigger
$result = $this -> call_trigger ( 'CONTACT_MODIFY' , $user );
2021-02-23 21:16:15 +01:00
if ( $result < 0 ) {
$error ++ ;
}
2020-10-31 14:32:18 +01:00
// End call triggers
2016-08-02 16:55:32 +02:00
}
2017-07-13 23:52:02 +02:00
2020-12-04 12:01:41 +01:00
if ( ! $error ) {
2020-10-31 14:32:18 +01:00
$this -> db -> commit ();
return 1 ;
2020-05-21 15:05:19 +02:00
} else {
2020-10-31 14:32:18 +01:00
dol_syslog ( get_class ( $this ) . " ::update Error " . $this -> error , LOG_ERR );
$this -> db -> rollback ();
return - $error ;
2016-08-02 16:55:32 +02:00
}
2006-11-18 22:59:10 +01:00
}
2006-02-25 00:16:35 +01:00
2011-09-16 19:57:09 +02:00
/**
2020-02-19 13:22:24 +01:00
* Load object contact .
2011-09-16 19:57:09 +02:00
*
2020-02-19 13:22:24 +01:00
* @ param int $id Id of contact
* @ param User $user Load also alerts of this user ( subscribing to alerts ) that want alerts about this contact
2020-10-31 14:32:18 +01:00
* @ param string $ref_ext External reference , not given by Dolibarr
* @ param string $email Email
2021-01-22 13:17:27 +01:00
* @ param int $loadalsoroles Load also roles . Try to always 0 here and load roles with a separate call of fetchRoles () .
2020-02-19 13:22:24 +01:00
* @ return int > 0 if OK , < 0 if KO or if two records found for same ref or idprof , 0 if not found .
2009-08-11 14:51:33 +02:00
*/
2020-02-19 13:22:24 +01:00
public function fetch ( $id , $user = null , $ref_ext = '' , $email = '' , $loadalsoroles = 0 )
2009-08-11 14:51:33 +02:00
{
global $langs ;
2019-04-11 18:04:18 +02:00
2019-12-03 11:17:29 +01:00
dol_syslog ( get_class ( $this ) . " ::fetch id= " . $id . " ref_ext= " . $ref_ext . " email= " . $email , LOG_DEBUG );
2015-08-29 13:45:23 +02:00
2021-02-23 21:16:15 +01:00
if ( empty ( $id ) && empty ( $ref_ext ) && empty ( $email )) {
2019-12-03 11:17:29 +01:00
$this -> error = 'BadParameter' ;
2015-07-19 23:39:07 +02:00
return - 1 ;
}
2020-02-19 13:22:24 +01:00
$langs -> loadLangs ( array ( " dict " , " companies " ));
2011-05-02 20:21:57 +02:00
2019-04-11 18:04:18 +02:00
$sql = " SELECT c.rowid, c.entity, c.fk_soc, c.ref_ext, c.civility as civility_code, c.lastname, c.firstname, " ;
2019-12-03 11:17:29 +01:00
$sql .= " c.address, c.statut, c.zip, c.town, " ;
$sql .= " c.fk_pays as country_id, " ;
$sql .= " c.fk_departement as state_id, " ;
$sql .= " c.birthday, " ;
$sql .= " c.poste, c.phone, c.phone_perso, c.phone_mobile, c.fax, c.email, " ;
$sql .= " c.socialnetworks, " ;
2020-10-31 14:32:18 +01:00
$sql .= " c.photo, " ;
2019-12-03 11:17:29 +01:00
$sql .= " c.priv, c.note_private, c.note_public, c.default_lang, c.canvas, " ;
2020-10-31 14:32:18 +01:00
$sql .= " c.fk_prospectcontactlevel, c.fk_stcommcontact, st.libelle as stcomm, st.picto as stcomm_picto, " ;
2019-12-03 11:17:29 +01:00
$sql .= " c.import_key, " ;
$sql .= " c.datec as date_creation, c.tms as date_modification, " ;
$sql .= " co.label as country, co.code as country_code, " ;
$sql .= " d.nom as state, d.code_departement as state_code, " ;
$sql .= " u.rowid as user_id, u.login as user_login, " ;
$sql .= " s.nom as socname, s.address as socaddress, s.zip as soccp, s.town as soccity, s.default_lang as socdefault_lang " ;
$sql .= " FROM " . MAIN_DB_PREFIX . " socpeople as c " ;
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . " c_country as co ON c.fk_pays = co.rowid " ;
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . " c_departements as d ON c.fk_departement = d.rowid " ;
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . " user as u ON c.rowid = u.fk_socpeople " ;
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . " societe as s ON c.fk_soc = s.rowid " ;
2020-10-31 14:32:18 +01:00
$sql .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'c_stcommcontact as st ON c.fk_stcommcontact = st.id' ;
2021-02-23 21:16:15 +01:00
if ( $id ) {
$sql .= " WHERE c.rowid = " . (( int ) $id );
} else {
2018-04-27 10:42:10 +02:00
$sql .= " WHERE c.entity IN ( " . getEntity ( $this -> element ) . " ) " ;
2018-11-12 14:49:08 +01:00
if ( $ref_ext ) {
$sql .= " AND c.ref_ext = ' " . $this -> db -> escape ( $ref_ext ) . " ' " ;
}
if ( $email ) {
$sql .= " AND c.email = ' " . $this -> db -> escape ( $email ) . " ' " ;
}
2018-04-27 10:42:10 +02:00
}
2009-08-11 14:51:33 +02:00
2019-12-03 11:17:29 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( $resql ) {
2020-02-19 13:22:24 +01:00
$num = $this -> db -> num_rows ( $resql );
2021-02-23 21:16:15 +01:00
if ( $num > 1 ) {
2020-02-19 13:22:24 +01:00
$this -> error = 'Fetch found several records. Rename one of contact to avoid duplicate.' ;
dol_syslog ( $this -> error , LOG_ERR );
2020-02-20 12:34:51 +01:00
2020-02-19 13:22:24 +01:00
return 2 ;
2021-02-23 21:16:15 +01:00
} elseif ( $num ) { // $num = 1
2009-08-11 14:51:33 +02:00
$obj = $this -> db -> fetch_object ( $resql );
2019-12-03 11:17:29 +01:00
$this -> id = $obj -> rowid ;
$this -> entity = $obj -> entity ;
$this -> ref = $obj -> rowid ;
$this -> ref_ext = $obj -> ref_ext ;
2019-04-11 18:04:18 +02:00
$this -> civility_code = $obj -> civility_code ;
2019-12-03 11:17:29 +01:00
$this -> civility = $obj -> civility_code ? ( $langs -> trans ( " Civility " . $obj -> civility_code ) != ( " Civility " . $obj -> civility_code ) ? $langs -> trans ( " Civility " . $obj -> civility_code ) : $obj -> civility_code ) : '' ;
2019-04-11 18:04:18 +02:00
2020-10-31 14:32:18 +01:00
$this -> lastname = $obj -> lastname ;
2019-12-03 11:17:29 +01:00
$this -> firstname = $obj -> firstname ;
$this -> address = $obj -> address ;
$this -> zip = $obj -> zip ;
$this -> town = $obj -> town ;
2011-03-09 11:33:35 +01:00
2018-08-26 18:08:10 +02:00
$this -> date_creation = $this -> db -> jdate ( $obj -> date_creation );
$this -> date_modification = $this -> db -> jdate ( $obj -> date_modification );
2018-09-02 18:18:10 +02:00
2019-12-03 11:17:29 +01:00
$this -> state_id = $obj -> state_id ;
$this -> state_code = $obj -> state_code ;
$this -> state = $obj -> state ;
2010-06-06 16:30:28 +02:00
2019-12-03 11:17:29 +01:00
$this -> country_id = $obj -> country_id ;
$this -> country_code = $obj -> country_id ? $obj -> country_code : '' ;
$this -> country = $obj -> country_id ? ( $langs -> trans ( 'Country' . $obj -> country_code ) != 'Country' . $obj -> country_code ? $langs -> transnoentities ( 'Country' . $obj -> country_code ) : $obj -> country ) : '' ;
2011-05-02 20:21:57 +02:00
2021-10-05 13:09:32 +02:00
$this -> fk_soc = $obj -> fk_soc ; // Both fk_soc and socid are used
$this -> socid = $obj -> fk_soc ; // Both fk_soc and socid are used
2011-03-09 11:33:35 +01:00
$this -> socname = $obj -> socname ;
2019-03-29 12:11:50 +01:00
$this -> poste = $obj -> poste ;
2019-12-03 11:17:29 +01:00
$this -> statut = $obj -> statut ;
2009-08-11 14:51:33 +02:00
2020-04-27 17:35:14 +02:00
$this -> fk_prospectlevel = $obj -> fk_prospectcontactlevel ;
2020-10-31 14:32:18 +01:00
$transcode = $langs -> trans ( 'StatusProspect' . $obj -> fk_stcommcontact );
$libelle = ( $transcode != 'StatusProspect' . $obj -> fk_stcommcontact ? $transcode : $obj -> stcomm );
$this -> stcomm_id = $obj -> fk_stcommcontact ; // id statut commercial
$this -> statut_commercial = $libelle ; // libelle statut commercial
$this -> stcomm_picto = $obj -> stcomm_picto ; // Picto statut commercial
2020-04-27 17:35:14 +02:00
2019-12-03 11:17:29 +01:00
$this -> phone_pro = trim ( $obj -> phone );
$this -> fax = trim ( $obj -> fax );
$this -> phone_perso = trim ( $obj -> phone_perso );
$this -> phone_mobile = trim ( $obj -> phone_mobile );
2009-08-11 14:51:33 +02:00
2019-03-29 12:11:50 +01:00
$this -> email = $obj -> email ;
2019-10-01 20:14:06 +02:00
$this -> socialnetworks = ( array ) json_decode ( $obj -> socialnetworks , true );
2019-03-29 12:11:50 +01:00
$this -> photo = $obj -> photo ;
2011-03-09 11:33:35 +01:00
$this -> priv = $obj -> priv ;
$this -> mail = $obj -> email ;
2009-08-11 14:51:33 +02:00
2019-12-03 11:17:29 +01:00
$this -> birthday = $this -> db -> jdate ( $obj -> birthday );
$this -> note = $obj -> note_private ; // deprecated
2013-04-09 17:18:07 +02:00
$this -> note_private = $obj -> note_private ;
2019-12-03 11:17:29 +01:00
$this -> note_public = $obj -> note_public ;
2011-03-09 11:33:35 +01:00
$this -> default_lang = $obj -> default_lang ;
2019-12-03 11:17:29 +01:00
$this -> user_id = $obj -> user_id ;
2011-03-09 11:33:35 +01:00
$this -> user_login = $obj -> user_login ;
2019-12-03 11:17:29 +01:00
$this -> canvas = $obj -> canvas ;
2009-08-11 14:51:33 +02:00
2012-01-18 00:16:02 +01:00
$this -> import_key = $obj -> import_key ;
2017-07-13 23:52:02 +02:00
2016-04-22 10:30:13 +02:00
// Define gender according to civility
2016-08-06 00:04:24 +02:00
$this -> setGenderFromCivility ();
2012-01-18 00:16:02 +01:00
2016-04-22 10:30:13 +02:00
// Search Dolibarr user linked to this contact
2009-08-11 14:51:33 +02:00
$sql = " SELECT u.rowid " ;
$sql .= " FROM " . MAIN_DB_PREFIX . " user as u " ;
2021-08-23 17:41:11 +02:00
$sql .= " WHERE u.fk_socpeople = " . (( int ) $this -> id );
2009-08-11 14:51:33 +02:00
2019-11-08 15:51:54 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( $resql ) {
if ( $this -> db -> num_rows ( $resql )) {
2009-08-11 14:51:33 +02:00
$uobj = $this -> db -> fetch_object ( $resql );
$this -> user_id = $uobj -> rowid ;
}
$this -> db -> free ( $resql );
2020-05-21 15:05:19 +02:00
} else {
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> error ();
2009-08-11 14:51:33 +02:00
return - 1 ;
}
2020-10-23 20:08:35 +02:00
// Retrieve all extrafield
2020-02-19 13:22:24 +01:00
// fetch optionals attributes and labels
$this -> fetch_optionals ();
2020-02-20 12:34:51 +01:00
2020-02-19 13:22:24 +01:00
// Load also alerts of this user
2021-02-23 21:16:15 +01:00
if ( $user ) {
2009-08-11 14:51:33 +02:00
$sql = " SELECT fk_user " ;
$sql .= " FROM " . MAIN_DB_PREFIX . " user_alert " ;
2021-08-23 17:41:11 +02:00
$sql .= " WHERE fk_user = " . (( int ) $user -> id ) . " AND fk_contact = " . (( int ) $id );
2009-08-11 14:51:33 +02:00
2019-11-08 15:51:54 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( $resql ) {
if ( $this -> db -> num_rows ( $resql )) {
2009-08-11 14:51:33 +02:00
$obj = $this -> db -> fetch_object ( $resql );
$this -> birthday_alert = 1 ;
}
$this -> db -> free ( $resql );
2020-05-21 15:05:19 +02:00
} else {
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> error ();
2009-08-11 14:51:33 +02:00
return - 1 ;
}
}
2007-09-10 02:17:28 +02:00
2020-02-19 13:22:24 +01:00
// Load also roles of this address
if ( $loadalsoroles ) {
$resultRole = $this -> fetchRoles ();
if ( $resultRole < 0 ) {
return $resultRole ;
}
2019-09-02 22:01:48 +02:00
}
2007-09-10 02:17:28 +02:00
return 1 ;
2020-05-21 15:05:19 +02:00
} else {
2019-11-08 15:51:54 +01:00
$this -> error = $langs -> trans ( " RecordNotFound " );
2007-09-10 02:17:28 +02:00
return 0 ;
}
2020-05-21 15:05:19 +02:00
} else {
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> error ();
2009-08-11 14:51:33 +02:00
return - 1 ;
}
}
2020-02-04 09:00:31 +01:00
2016-08-06 00:04:24 +02:00
/**
2020-02-04 09:00:31 +01:00
* Set the property " gender " of this class , based on the property " civility_id "
* or use property " civility_code " as fallback , when " civility_id " is not available .
2017-07-13 23:52:02 +02:00
*
2016-08-06 00:04:24 +02:00
* @ return void
*/
2019-02-25 00:56:48 +01:00
public function setGenderFromCivility ()
2016-08-06 00:04:24 +02:00
{
2020-02-04 09:00:31 +01:00
unset ( $this -> gender );
2021-02-23 21:16:15 +01:00
if ( in_array ( $this -> civility_id , array ( 'MR' )) || in_array ( $this -> civility_code , array ( 'MR' ))) {
2020-02-04 09:00:31 +01:00
$this -> gender = 'man' ;
2021-02-23 21:16:15 +01:00
} elseif ( in_array ( $this -> civility_id , array ( 'MME' , 'MLE' )) || in_array ( $this -> civility_code , array ( 'MME' , 'MLE' ))) {
2020-02-04 09:00:31 +01:00
$this -> gender = 'woman' ;
}
2017-07-13 23:52:02 +02:00
}
2020-10-31 14:32:18 +01:00
// phpcs:disable PEAR.NamingConventions.ValidFunctionName.ScopeNotCamelCaps
2011-07-04 11:36:29 +02:00
/**
2016-02-24 11:17:47 +01:00
* Load number of elements the contact is used as a link for
2011-09-16 19:57:09 +02:00
* ref_facturation
* ref_contrat
2016-02-24 11:17:47 +01:00
* ref_commande ( for order and / or shipments )
2011-09-16 19:57:09 +02:00
* ref_propale
*
2020-10-31 14:32:18 +01:00
* @ return int < 0 if KO , >= 0 if OK
2009-08-11 14:51:33 +02:00
*/
2019-02-25 00:56:48 +01:00
public function load_ref_elements ()
2009-08-11 14:51:33 +02:00
{
2020-10-31 14:32:18 +01:00
// phpcs:enable
2009-08-11 14:51:33 +02:00
// Compte les elements pour lesquels il est contact
2019-11-08 15:51:54 +01:00
$sql = " SELECT tc.element, count(ec.rowid) as nb " ;
$sql .= " FROM " . MAIN_DB_PREFIX . " element_contact as ec, " . MAIN_DB_PREFIX . " c_type_contact as tc " ;
$sql .= " WHERE ec.fk_c_type_contact = tc.rowid " ;
2021-08-23 17:41:11 +02:00
$sql .= " AND fk_socpeople = " . (( int ) $this -> id );
2019-11-08 15:51:54 +01:00
$sql .= " AND tc.source = 'external' " ;
$sql .= " GROUP BY tc.element " ;
2009-08-11 14:51:33 +02:00
2014-06-12 11:31:53 +02:00
dol_syslog ( get_class ( $this ) . " ::load_ref_elements " , LOG_DEBUG );
2009-08-11 14:51:33 +02:00
2019-11-08 15:51:54 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( $resql ) {
while ( $obj = $this -> db -> fetch_object ( $resql )) {
if ( $obj -> nb ) {
if ( $obj -> element == 'facture' ) {
$this -> ref_facturation = $obj -> nb ;
} elseif ( $obj -> element == 'contrat' ) {
$this -> ref_contrat = $obj -> nb ;
} elseif ( $obj -> element == 'commande' ) {
$this -> ref_commande = $obj -> nb ;
} elseif ( $obj -> element == 'propal' ) {
$this -> ref_propal = $obj -> nb ;
}
2009-08-11 14:51:33 +02:00
}
2006-02-25 00:16:35 +01:00
}
2009-08-11 14:51:33 +02:00
$this -> db -> free ( $resql );
return 0 ;
2020-05-21 15:05:19 +02:00
} else {
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> lasterror ();
2009-08-11 14:51:33 +02:00
return - 1 ;
}
}
2006-02-25 00:16:35 +01:00
2011-07-04 11:36:29 +02:00
/**
2021-06-10 00:09:38 +02:00
* Delete a contact from database
* // TODO Add $user as first param
2011-09-16 19:57:09 +02:00
*
2021-06-10 00:09:38 +02:00
* @ param int $notrigger Disable all trigger
* @ return int < 0 if KO , > 0 if OK
2009-08-11 14:51:33 +02:00
*/
2019-02-25 00:56:48 +01:00
public function delete ( $notrigger = 0 )
2006-02-25 00:16:35 +01:00
{
2008-04-10 01:07:13 +02:00
global $conf , $langs , $user ;
2009-01-19 23:41:26 +01:00
2019-11-08 15:51:54 +01:00
$error = 0 ;
2009-01-19 23:41:26 +01:00
2007-09-16 05:55:35 +02:00
$this -> db -> begin ();
2009-01-19 23:41:26 +01:00
2022-10-03 15:16:41 +02:00
if ( ! $error && ! $notrigger ) {
// Call trigger
$result = $this -> call_trigger ( 'CONTACT_DELETE' , $user );
if ( $result < 0 ) {
$error ++ ;
}
// End call triggers
}
2021-02-23 21:16:15 +01:00
if ( ! $error ) {
2007-09-16 05:55:35 +02:00
// Get all rowid of element_contact linked to a type that is link to llx_socpeople
$sql = " SELECT ec.rowid " ;
2019-11-08 15:51:54 +01:00
$sql .= " FROM " . MAIN_DB_PREFIX . " element_contact ec, " ;
$sql .= " " . MAIN_DB_PREFIX . " c_type_contact tc " ;
2021-08-23 17:41:11 +02:00
$sql .= " WHERE ec.fk_socpeople= " . (( int ) $this -> id );
2019-11-08 15:51:54 +01:00
$sql .= " AND ec.fk_c_type_contact=tc.rowid " ;
$sql .= " AND tc.source='external' " ;
2020-06-01 10:51:50 +02:00
dol_syslog ( __METHOD__ , LOG_DEBUG );
2007-09-16 05:55:35 +02:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( $resql ) {
2019-11-08 15:51:54 +01:00
$num = $this -> db -> num_rows ( $resql );
2009-01-19 23:41:26 +01:00
2019-11-08 15:51:54 +01:00
$i = 0 ;
2021-02-23 21:16:15 +01:00
while ( $i < $num && ! $error ) {
2007-09-16 05:55:35 +02:00
$obj = $this -> db -> fetch_object ( $resql );
$sqldel = " DELETE FROM " . MAIN_DB_PREFIX . " element_contact " ;
2021-06-09 15:36:47 +02:00
$sqldel .= " WHERE rowid = " . (( int ) $obj -> rowid );
2020-06-01 10:51:50 +02:00
dol_syslog ( __METHOD__ , LOG_DEBUG );
2007-09-16 05:55:35 +02:00
$result = $this -> db -> query ( $sqldel );
2021-02-23 21:16:15 +01:00
if ( ! $result ) {
2007-09-16 05:55:35 +02:00
$error ++ ;
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> error () . ' sql=' . $sqldel ;
2007-09-16 05:55:35 +02:00
}
$i ++ ;
}
2020-05-21 15:05:19 +02:00
} else {
2007-09-16 05:55:35 +02:00
$error ++ ;
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> error () . ' sql=' . $sql ;
2006-11-18 22:59:10 +01:00
}
}
2009-01-19 23:41:26 +01:00
2021-02-23 21:16:15 +01:00
if ( ! $error ) {
2019-09-02 22:01:48 +02:00
// Remove Roles
2021-08-23 17:41:11 +02:00
$sql = " DELETE FROM " . MAIN_DB_PREFIX . " societe_contacts WHERE fk_socpeople = " . (( int ) $this -> id );
2020-06-01 10:51:50 +02:00
dol_syslog ( __METHOD__ , LOG_DEBUG );
2019-11-08 15:51:54 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( ! $resql ) {
2019-09-02 22:01:48 +02:00
$error ++ ;
$this -> error .= $this -> db -> lasterror ();
2019-11-08 15:51:54 +01:00
$errorflag = - 1 ;
2019-09-02 22:01:48 +02:00
}
}
2021-02-23 21:16:15 +01:00
if ( ! $error ) {
2021-01-07 17:23:02 +01:00
// Remove Roles
2021-08-23 17:41:11 +02:00
$sql = " DELETE FROM " . MAIN_DB_PREFIX . " societe_contacts WHERE fk_socpeople = " . (( int ) $this -> id );
2021-01-07 17:23:02 +01:00
dol_syslog ( __METHOD__ , LOG_DEBUG );
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( ! $resql ) {
2021-01-07 17:23:02 +01:00
$error ++ ;
$this -> error .= $this -> db -> lasterror ();
$errorflag = - 1 ;
}
}
2021-02-23 21:16:15 +01:00
if ( ! $error ) {
2013-09-05 21:03:03 +02:00
// Remove category
2021-08-23 17:41:11 +02:00
$sql = " DELETE FROM " . MAIN_DB_PREFIX . " categorie_contact WHERE fk_socpeople = " . (( int ) $this -> id );
2020-06-01 10:51:50 +02:00
dol_syslog ( __METHOD__ , LOG_DEBUG );
2019-11-08 15:51:54 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( ! $resql ) {
2013-09-05 21:03:03 +02:00
$error ++ ;
$this -> error .= $this -> db -> lasterror ();
2019-11-08 15:51:54 +01:00
$errorflag = - 1 ;
2013-09-05 21:03:03 +02:00
}
}
2021-02-23 21:16:15 +01:00
if ( ! $error ) {
2007-09-16 05:55:35 +02:00
$sql = " DELETE FROM " . MAIN_DB_PREFIX . " socpeople " ;
2021-08-27 18:18:50 +02:00
$sql .= " WHERE rowid = " . (( int ) $this -> id );
2020-06-01 10:51:50 +02:00
dol_syslog ( __METHOD__ , LOG_DEBUG );
2007-09-16 05:55:35 +02:00
$result = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( ! $result ) {
2007-09-16 05:55:35 +02:00
$error ++ ;
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> error () . ' sql=' . $sql ;
2007-09-16 05:55:35 +02:00
}
}
2013-04-06 00:37:20 +02:00
2012-12-16 23:18:20 +01:00
// Removed extrafields
2020-10-31 14:32:18 +01:00
if ( ! $error ) {
// For avoid conflicts if trigger used
2019-11-08 15:51:54 +01:00
$result = $this -> deleteExtraFields ();
2021-02-23 21:16:15 +01:00
if ( $result < 0 ) {
$error ++ ;
}
2012-12-16 23:18:20 +01:00
}
2007-09-16 05:55:35 +02:00
2021-02-23 21:16:15 +01:00
if ( ! $error ) {
2007-09-16 05:55:35 +02:00
$this -> db -> commit ();
return 1 ;
2020-05-21 15:05:19 +02:00
} else {
2007-09-16 05:55:35 +02:00
$this -> db -> rollback ();
2019-01-27 11:55:16 +01:00
dol_syslog ( " Error " . $this -> error , LOG_ERR );
2006-11-19 02:46:32 +01:00
return - 1 ;
2006-11-18 22:59:10 +01:00
}
2006-02-25 00:16:35 +01:00
}
2006-06-24 17:13:29 +02:00
2009-01-19 23:41:26 +01:00
2011-09-16 19:57:09 +02:00
/**
* Charge les informations sur le contact , depuis la base
*
* @ param int $id Id du contact a charger
* @ return void
2009-08-11 14:51:33 +02:00
*/
2019-02-25 00:56:48 +01:00
public function info ( $id )
2009-08-11 14:51:33 +02:00
{
2010-01-13 19:51:19 +01:00
$sql = " SELECT c.rowid, c.datec as datec, c.fk_user_creat, " ;
2019-11-08 15:51:54 +01:00
$sql .= " c.tms as tms, c.fk_user_modif " ;
$sql .= " FROM " . MAIN_DB_PREFIX . " socpeople as c " ;
2021-06-09 15:36:47 +02:00
$sql .= " WHERE c.rowid = " . (( int ) $id );
2009-08-11 14:51:33 +02:00
2019-11-08 15:51:54 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( $resql ) {
if ( $this -> db -> num_rows ( $resql )) {
2009-08-11 14:51:33 +02:00
$obj = $this -> db -> fetch_object ( $resql );
2018-09-16 19:19:45 +02:00
$this -> id = $obj -> rowid ;
2009-08-11 14:51:33 +02:00
if ( $obj -> fk_user_creat ) {
2010-04-28 09:31:34 +02:00
$cuser = new User ( $this -> db );
$cuser -> fetch ( $obj -> fk_user_creat );
2019-11-08 15:51:54 +01:00
$this -> user_creation = $cuser ;
2009-08-11 14:51:33 +02:00
}
if ( $obj -> fk_user_modif ) {
2010-04-28 09:31:34 +02:00
$muser = new User ( $this -> db );
$muser -> fetch ( $obj -> fk_user_modif );
2009-08-11 14:51:33 +02:00
$this -> user_modification = $muser ;
}
2010-01-13 19:51:19 +01:00
$this -> date_creation = $this -> db -> jdate ( $obj -> datec );
$this -> date_modification = $this -> db -> jdate ( $obj -> tms );
2009-08-11 14:51:33 +02:00
}
$this -> db -> free ( $resql );
2020-05-21 15:05:19 +02:00
} else {
2009-08-11 14:51:33 +02:00
print $this -> db -> error ();
}
}
2010-02-21 22:21:12 +01:00
/**
2011-09-16 19:57:09 +02:00
* Return number of mass Emailing received by this contacts with its email
*
* @ return int Number of EMailings
2009-08-11 14:51:33 +02:00
*/
2019-02-25 00:56:48 +01:00
public function getNbOfEMailings ()
2009-08-11 14:51:33 +02:00
{
$sql = " SELECT count(mc.email) as nb " ;
2019-11-08 15:51:54 +01:00
$sql .= " FROM " . MAIN_DB_PREFIX . " mailing_cibles as mc, " . MAIN_DB_PREFIX . " mailing as m " ;
$sql .= " WHERE mc.fk_mailing=m.rowid AND mc.email = ' " . $this -> db -> escape ( $this -> email ) . " ' " ;
$sql .= " AND m.entity IN ( " . getEntity ( $this -> element ) . " ) AND mc.statut NOT IN (-1,0) " ; // -1 error, 0 not sent, 1 sent with success
2012-09-17 01:39:30 +02:00
2019-11-08 15:51:54 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( $resql ) {
2009-08-11 14:51:33 +02:00
$obj = $this -> db -> fetch_object ( $resql );
2019-11-08 15:51:54 +01:00
$nb = $obj -> nb ;
2009-08-11 14:51:33 +02:00
$this -> db -> free ( $resql );
return $nb ;
2020-05-21 15:05:19 +02:00
} else {
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> error ();
2009-08-11 14:51:33 +02:00
return - 1 ;
}
}
2006-08-05 18:44:43 +02:00
/**
2011-09-16 19:57:09 +02:00
* Return name of contact with link ( and eventually picto )
2014-05-05 00:23:09 +02:00
* Use $this -> id , $this -> lastname , $this -> firstname , this -> civility_id
2011-09-16 19:57:09 +02:00
*
2022-02-02 17:57:20 +01:00
* @ param int $withpicto Include picto with link ( 1 = picto + name , 2 = picto only , - 1 = photo + name , - 2 = photo only )
2017-10-03 16:00:52 +02:00
* @ param string $option Where the link point to
* @ param int $maxlen Max length of
* @ param string $moreparam Add more param into URL
2020-10-31 14:32:18 +01:00
* @ param int $save_lastsearch_value - 1 = Auto , 0 = No save of lastsearch_values when clicking , 1 = Save lastsearch_values whenclicking
2018-03-12 19:02:30 +01:00
* @ param int $notooltip 1 = Disable tooltip
2022-01-15 12:56:19 +01:00
* @ param string $morecss Add more css on link
2017-10-03 16:00:52 +02:00
* @ return string String with URL
2006-08-05 18:44:43 +02:00
*/
2022-01-15 12:56:19 +01:00
public function getNomUrl ( $withpicto = 0 , $option = '' , $maxlen = 0 , $moreparam = '' , $save_lastsearch_value = - 1 , $notooltip = 0 , $morecss = '' )
2006-08-05 18:44:43 +02:00
{
2016-07-16 18:00:53 +02:00
global $conf , $langs , $hookmanager ;
2009-01-19 23:41:26 +01:00
2020-02-10 12:56:08 +01:00
$result = '' ; $label = '' ;
2021-02-23 21:16:15 +01:00
if ( ! empty ( $this -> photo ) && class_exists ( 'Form' )) {
2022-01-05 10:43:05 +01:00
$label .= '<div class="photointooltip floatright">' ;
$label .= Form :: showphoto ( 'contact' , $this , 0 , 40 , 0 , 'photoref' , 'mini' , 0 ); // Important, we must force height so image will have height tags and if image is inside a tooltip, the tooltip manager can calculate height and position correctly the tooltip.
$label .= '</div>' ;
//$label .= '<div style="clear: both;"></div>';
2020-02-10 12:56:08 +01:00
}
2020-11-05 22:25:14 +01:00
$label .= img_picto ( '' , $this -> picto ) . ' <u class="paddingrightonly">' . $langs -> trans ( " Contact " ) . '</u>' ;
$label .= ' ' . $this -> getLibStatut ( 4 );
2020-10-31 14:32:18 +01:00
$label .= '<br><b>' . $langs -> trans ( " Name " ) . ':</b> ' . $this -> getFullName ( $langs );
//if ($this->civility_id) $label.= '<br><b>' . $langs->trans("Civility") . ':</b> '.$this->civility_id; // TODO Translate cibilty_id code
2021-02-23 21:16:15 +01:00
if ( ! empty ( $this -> poste )) {
$label .= '<br><b>' . $langs -> trans ( " Poste " ) . ':</b> ' . $this -> poste ;
}
2020-10-31 14:32:18 +01:00
$label .= '<br><b>' . $langs -> trans ( " EMail " ) . ':</b> ' . $this -> email ;
$phonelist = array ();
2020-12-04 20:43:11 +01:00
$country_code = empty ( $this -> country_code ) ? '' : $this -> country_code ;
2021-02-23 21:16:15 +01:00
if ( $this -> phone_pro ) {
$phonelist [] = dol_print_phone ( $this -> phone_pro , $country_code , $this -> id , 0 , '' , ' ' , 'phone' );
}
if ( $this -> phone_mobile ) {
$phonelist [] = dol_print_phone ( $this -> phone_mobile , $country_code , $this -> id , 0 , '' , ' ' , 'mobile' );
}
if ( $this -> phone_perso ) {
$phonelist [] = dol_print_phone ( $this -> phone_perso , $country_code , $this -> id , 0 , '' , ' ' , 'phone' );
}
2020-10-31 14:32:18 +01:00
$label .= '<br><b>' . $langs -> trans ( " Phone " ) . ':</b> ' . implode ( ' ' , $phonelist );
$label .= '<br><b>' . $langs -> trans ( " Address " ) . ':</b> ' . dol_format_address ( $this , 1 , ' ' , $langs );
$url = DOL_URL_ROOT . '/contact/card.php?id=' . $this -> id ;
2021-02-23 21:16:15 +01:00
if ( $option !== 'nolink' ) {
2020-10-31 14:32:18 +01:00
// Add param to save lastsearch_values or not
$add_save_lastsearch_values = ( $save_lastsearch_value == 1 ? 1 : 0 );
2021-02-23 21:16:15 +01:00
if ( $save_lastsearch_value == - 1 && preg_match ( '/list\.php/' , $_SERVER [ " PHP_SELF " ])) {
$add_save_lastsearch_values = 1 ;
}
if ( $add_save_lastsearch_values ) {
$url .= '&save_lastsearch_values=1' ;
}
2020-10-31 14:32:18 +01:00
}
$url .= $moreparam ;
$linkclose = " " ;
2018-03-12 19:02:30 +01:00
if ( empty ( $notooltip )) {
2021-02-23 21:16:15 +01:00
if ( ! empty ( $conf -> global -> MAIN_OPTIMIZEFORTEXTBROWSER )) {
2020-10-31 14:32:18 +01:00
$label = $langs -> trans ( " ShowContact " );
$linkclose .= ' alt="' . dol_escape_htmltag ( $label , 1 ) . '"' ;
}
2021-02-23 21:16:15 +01:00
$linkclose .= ' title="' . dol_escape_htmltag ( $label , 1 ) . '"' ;
2022-01-15 12:56:19 +01:00
$linkclose .= ' class="classfortooltip' . ( $morecss ? ' ' . $morecss : '' ) . '"' ;
2016-07-16 18:00:53 +02:00
}
2006-08-05 18:44:43 +02:00
2018-06-04 12:55:55 +02:00
$linkstart = '<a href="' . $url . '"' ;
2019-11-08 15:51:54 +01:00
$linkstart .= $linkclose . '>' ;
$linkend = '</a>' ;
2017-07-13 23:52:02 +02:00
2021-02-23 21:16:15 +01:00
if ( $option == 'xxx' ) {
2017-10-03 16:00:52 +02:00
$linkstart = '<a href="' . DOL_URL_ROOT . '/contact/card.php?id=' . $this -> id . $moreparam . '" title="' . dol_escape_htmltag ( $label , 1 ) . '" class="classfortooltip">' ;
2019-11-08 15:51:54 +01:00
$linkend = '</a>' ;
2006-08-05 18:44:43 +02:00
}
2017-07-13 23:52:02 +02:00
2019-11-08 15:51:54 +01:00
$result .= $linkstart ;
2021-02-23 21:16:15 +01:00
if ( $withpicto ) {
2022-02-02 17:57:20 +01:00
if ( $withpicto < 0 ) {
2022-01-15 12:56:19 +01:00
$result .= '<!-- picto photo user --><span class="nopadding userimg' . ( $morecss ? ' ' . $morecss : '' ) . '">' . Form :: showphoto ( 'contact' , $this , 0 , 0 , 0 , 'userphoto' . ( $withpicto == - 3 ? 'small' : '' ), 'mini' , 0 , 1 ) . '</span>' ;
2021-03-04 10:36:17 +01:00
} else {
2021-03-04 10:33:18 +01:00
$result .= img_object (( $notooltip ? '' : $label ), ( $this -> picto ? $this -> picto : 'generic' ), ( $notooltip ? (( $withpicto != 2 ) ? 'class="paddingright"' : '' ) : 'class="' . (( $withpicto != 2 ) ? 'paddingright ' : '' ) . 'classfortooltip"' ), 0 , 0 , $notooltip ? 0 : 1 );
2021-03-04 10:15:41 +01:00
}
2021-02-23 21:16:15 +01:00
}
2021-03-04 10:15:41 +01:00
if ( $withpicto != 2 && $withpicto != - 2 ) {
2022-02-02 17:57:20 +01:00
$result .= '<span class="valigmiddle">' . ( $maxlen ? dol_trunc ( $this -> getFullName ( $langs ), $maxlen ) : $this -> getFullName ( $langs )) . '</span>' ;
2021-02-23 21:16:15 +01:00
}
2019-11-08 15:51:54 +01:00
$result .= $linkend ;
2017-11-02 15:03:09 +01:00
2018-03-15 20:46:55 +01:00
global $action ;
$hookmanager -> initHooks ( array ( 'contactdao' ));
2022-02-15 18:31:05 +01:00
$parameters = array ( 'id' => $this -> id , 'getnomurl' => & $result );
2019-11-08 15:51:54 +01:00
$reshook = $hookmanager -> executeHooks ( 'getNomUrl' , $parameters , $this , $action ); // Note that $action and $object may have been modified by some hooks
2021-02-23 21:16:15 +01:00
if ( $reshook > 0 ) {
$result = $hookmanager -> resPrint ;
} else {
$result .= $hookmanager -> resPrint ;
}
2018-03-15 20:46:55 +01:00
2006-08-05 18:44:43 +02:00
return $result ;
2006-09-01 01:44:34 +02:00
}
2009-08-11 14:51:33 +02:00
/**
2013-05-12 17:09:48 +02:00
* Return civility label of contact
2011-09-16 19:57:09 +02:00
*
2013-05-12 17:09:48 +02:00
* @ return string Translated name of civility
2009-08-11 14:51:33 +02:00
*/
2019-02-25 00:56:48 +01:00
public function getCivilityLabel ()
2009-08-11 14:51:33 +02:00
{
global $langs ;
2008-01-10 18:12:07 +01:00
2019-11-08 15:51:54 +01:00
$code = ( $this -> civility_code ? $this -> civility_code : ( ! empty ( $this -> civility_id ) ? $this -> civility : ( ! empty ( $this -> civilite ) ? $this -> civilite : '' )));
2021-02-23 21:16:15 +01:00
if ( empty ( $code )) {
return '' ;
}
2019-08-15 20:39:47 +02:00
$langs -> load ( " dict " );
return $langs -> getLabelFromKey ( $this -> db , " Civility " . $code , " c_civility " , " code " , " label " , $code );
2009-08-11 14:51:33 +02:00
}
2008-01-10 18:12:07 +01:00
2007-05-04 23:19:15 +02:00
/**
2013-09-10 13:45:39 +02:00
* Return label of contact status
2011-09-16 19:57:09 +02:00
*
2013-09-10 13:45:39 +02:00
* @ param int $mode 0 = libelle long , 1 = libelle court , 2 = Picto + Libelle court , 3 = Picto , 4 = Picto + Libelle long , 5 = Libelle court + Picto
* @ return string Label of contact status
2007-05-04 23:19:15 +02:00
*/
2019-02-25 00:56:48 +01:00
public function getLibStatut ( $mode )
2007-05-04 23:19:15 +02:00
{
2019-01-27 11:55:16 +01:00
return $this -> LibStatut ( $this -> statut , $mode );
2013-07-10 12:28:28 +02:00
}
2013-09-09 02:37:11 +02:00
2020-10-31 14:32:18 +01:00
// phpcs:disable PEAR.NamingConventions.ValidFunctionName.ScopeNotCamelCaps
2007-05-04 23:19:15 +02:00
/**
2011-09-16 19:57:09 +02:00
* Renvoi le libelle d ' un statut donne
*
2019-10-24 16:38:06 +02:00
* @ param int $status Id statut
2011-09-16 19:57:09 +02:00
* @ param int $mode 0 = libelle long , 1 = libelle court , 2 = Picto + Libelle court , 3 = Picto , 4 = Picto + Libelle long , 5 = Libelle court + Picto
* @ return string Libelle
2007-05-04 23:19:15 +02:00
*/
2019-10-24 16:38:06 +02:00
public function LibStatut ( $status , $mode )
2007-05-04 23:19:15 +02:00
{
2020-10-31 14:32:18 +01:00
// phpcs:enable
2007-05-04 23:19:15 +02:00
global $langs ;
2009-01-19 23:41:26 +01:00
2019-11-01 12:52:03 +01:00
$labelStatus = array (
2019-10-28 08:16:43 +01:00
0 => 'ActivityCeased' ,
1 => 'InActivity' ,
4 => 'InActivity' ,
5 => 'ActivityCeased' ,
);
2019-11-01 12:52:03 +01:00
$labelStatusShort = array (
2019-10-28 08:16:43 +01:00
0 => 'ActivityCeased' ,
1 => 'InActivity' ,
4 => 'InActivity' ,
5 => 'ActivityCeased' ,
);
2019-10-24 16:38:06 +02:00
$statusType = 'status4' ;
2021-02-23 21:16:15 +01:00
if ( $status == 0 || $status == 5 ) {
$statusType = 'status5' ;
}
2019-10-24 16:38:06 +02:00
2021-10-16 19:37:57 +02:00
$label = $langs -> transnoentitiesnoconv ( $labelStatus [ $status ]);
$labelshort = $langs -> transnoentitiesnoconv ( $labelStatusShort [ $status ]);
2019-10-24 16:38:06 +02:00
return dolGetStatus ( $label , $labelshort , '' , $statusType , $mode );
2007-05-04 23:19:15 +02:00
}
2013-10-08 00:42:40 +02:00
2020-10-31 14:32:18 +01:00
// phpcs:disable PEAR.NamingConventions.ValidFunctionName.ScopeNotCamelCaps
2008-03-31 00:25:39 +02:00
/**
2011-09-16 19:57:09 +02:00
* Return translated label of Public or Private
*
2019-10-24 16:38:06 +02:00
* @ param int $status Type ( 0 = public , 1 = private )
2011-09-16 19:57:09 +02:00
* @ return string Label translated
2008-03-31 00:25:39 +02:00
*/
2019-10-24 16:38:06 +02:00
public function LibPubPriv ( $status )
2008-03-31 00:25:39 +02:00
{
2020-10-31 14:32:18 +01:00
// phpcs:enable
2008-03-31 00:25:39 +02:00
global $langs ;
2021-02-23 21:16:15 +01:00
if ( $status == '1' ) {
return $langs -> trans ( 'ContactPrivate' );
} else {
return $langs -> trans ( 'ContactPublic' );
}
2008-03-31 00:25:39 +02:00
}
2006-11-19 02:46:32 +01:00
/**
2020-10-31 14:32:18 +01:00
* Initialise an instance with random values .
* Used to build previews or test instances .
* id must be 0 if object instance is a specimen .
*
* @ return int > 0 if ok
2006-11-19 02:46:32 +01:00
*/
2019-02-25 00:56:48 +01:00
public function initAsSpecimen ()
2006-11-19 02:46:32 +01:00
{
2014-02-08 12:58:27 +01:00
// Get first id of existing company and save it into $socid
$socid = 0 ;
$sql = " SELECT rowid FROM " . MAIN_DB_PREFIX . " societe ORDER BY rowid LIMIT 1 " ;
2006-11-19 02:46:32 +01:00
$resql = $this -> db -> query ( $sql );
2019-02-25 00:56:48 +01:00
if ( $resql ) {
2014-02-08 12:58:27 +01:00
$obj = $this -> db -> fetch_object ( $resql );
2021-02-23 21:16:15 +01:00
if ( $obj ) {
$socid = $obj -> rowid ;
}
2006-11-19 02:46:32 +01:00
}
2009-08-12 02:40:16 +02:00
// Initialise parameters
2019-11-08 15:51:54 +01:00
$this -> id = 0 ;
2020-11-05 14:48:41 +01:00
$this -> entity = 1 ;
2019-11-08 15:51:54 +01:00
$this -> specimen = 1 ;
2012-06-26 13:11:04 +02:00
$this -> lastname = 'DOLIBARR' ;
2011-12-30 14:18:19 +01:00
$this -> firstname = 'SPECIMEN' ;
2013-04-06 00:37:20 +02:00
$this -> address = '21 jump street' ;
$this -> zip = '99999' ;
$this -> town = 'MyTown' ;
2011-12-30 14:18:19 +01:00
$this -> country_id = 1 ;
$this -> country_code = 'FR' ;
$this -> country = 'France' ;
2006-11-19 02:46:32 +01:00
$this -> email = 'specimen@specimen.com' ;
2019-09-12 18:12:28 +02:00
$this -> socialnetworks = array (
'skype' => 'tom.hanson' ,
);
2013-06-05 16:24:32 +02:00
$this -> phone_pro = '0909090901' ;
$this -> phone_perso = '0909090902' ;
$this -> phone_mobile = '0909090903' ;
$this -> fax = '0909090909' ;
2013-04-06 03:40:55 +02:00
2019-11-08 15:51:54 +01:00
$this -> note_public = 'This is a comment (public)' ;
$this -> note_private = 'This is a comment (private)' ;
2013-04-06 00:37:20 +02:00
2014-02-08 12:58:27 +01:00
$this -> socid = $socid ;
2019-11-08 15:51:54 +01:00
$this -> statut = 1 ;
2019-09-07 14:48:25 +02:00
return 1 ;
2013-07-10 12:28:28 +02:00
}
2013-09-09 02:37:11 +02:00
2013-07-10 12:28:28 +02:00
/**
* Change status of a user
*
2019-10-24 16:38:06 +02:00
* @ param int $status Status to set
2013-07-10 12:28:28 +02:00
* @ return int < 0 if KO , 0 if nothing is done , > 0 if OK
*/
2019-10-24 16:38:06 +02:00
public function setstatus ( $status )
2013-07-10 12:28:28 +02:00
{
2019-11-08 15:51:54 +01:00
global $conf , $langs , $user ;
2013-07-10 12:28:28 +02:00
2019-11-08 15:51:54 +01:00
$error = 0 ;
2013-07-10 12:28:28 +02:00
// Check parameters
2021-02-23 21:16:15 +01:00
if ( $this -> statut == $status ) {
return 0 ;
} else {
$this -> statut = $status ;
}
2013-07-10 12:28:28 +02:00
$this -> db -> begin ();
// Desactive utilisateur
$sql = " UPDATE " . MAIN_DB_PREFIX . " socpeople " ;
2021-03-30 03:37:54 +02:00
$sql .= " SET statut = " . (( int ) $this -> statut );
2021-03-30 17:53:25 +02:00
$sql .= " WHERE rowid = " . (( int ) $this -> id );
2013-07-10 12:28:28 +02:00
$result = $this -> db -> query ( $sql );
2014-06-12 11:31:53 +02:00
dol_syslog ( get_class ( $this ) . " ::setstatus " , LOG_DEBUG );
2021-02-23 21:16:15 +01:00
if ( $result ) {
2020-10-31 14:32:18 +01:00
// Call trigger
$result = $this -> call_trigger ( 'CONTACT_ENABLEDISABLE' , $user );
2021-02-23 21:16:15 +01:00
if ( $result < 0 ) {
$error ++ ;
}
2020-10-31 14:32:18 +01:00
// End call triggers
2013-07-10 12:28:28 +02:00
}
2021-02-23 21:16:15 +01:00
if ( $error ) {
2013-07-10 12:28:28 +02:00
$this -> db -> rollback ();
return - $error ;
2020-05-21 15:05:19 +02:00
} else {
2013-07-10 12:28:28 +02:00
$this -> db -> commit ();
return 1 ;
}
2006-11-19 02:46:32 +01:00
}
2015-09-30 18:46:51 +02:00
/**
* Sets object to supplied categories .
*
* Deletes object from existing categories not supplied .
* Adds it to non existing supplied categories .
* Existing categories are left untouch .
*
* @ param int [] | int $categories Category or categories IDs
2020-10-31 14:32:18 +01:00
* @ return void
2015-09-30 18:46:51 +02:00
*/
public function setCategories ( $categories )
{
2019-11-08 15:51:54 +01:00
require_once DOL_DOCUMENT_ROOT . '/categories/class/categorie.class.php' ;
2020-12-23 23:32:50 +01:00
return parent :: setCategoriesCommon ( $categories , Categorie :: TYPE_CONTACT );
2015-09-30 18:46:51 +02:00
}
2015-04-18 18:11:01 +02:00
/**
* Function used to replace a thirdparty id with another one .
*
* @ param DoliDB $db Database handler
* @ param int $origin_id Old thirdparty id
* @ param int $dest_id New thirdparty id
* @ return bool
*/
public static function replaceThirdparty ( DoliDB $db , $origin_id , $dest_id )
{
$tables = array (
2020-05-18 10:54:25 +02:00
'socpeople' , 'societe_contacts'
2015-04-18 18:11:01 +02:00
);
return CommonObject :: commonReplaceThirdparty ( $db , $origin_id , $dest_id , $tables );
}
2019-09-02 14:47:32 +02:00
/**
2021-01-22 10:51:47 +01:00
* Fetch roles ( default contact of some companies ) for the current contact .
* This load the array -> roles .
2019-09-02 14:47:32 +02:00
*
2021-01-22 13:17:27 +01:00
* @ return int < 0 if KO , Nb of roles found if OK
* @ see updateRoles ()
2019-09-02 14:47:32 +02:00
*/
2019-09-02 22:01:48 +02:00
public function fetchRoles ()
2019-09-02 14:47:32 +02:00
{
global $langs ;
2019-11-08 15:51:54 +01:00
$error = 0 ;
$num = 0 ;
2019-09-02 14:47:32 +02:00
2021-01-22 10:51:47 +01:00
$sql = " SELECT tc.rowid, tc.element, tc.source, tc.code, tc.libelle as label, sc.rowid as contactroleid, sc.fk_soc as socid " ;
$sql .= " FROM " . MAIN_DB_PREFIX . " societe_contacts as sc, " . MAIN_DB_PREFIX . " c_type_contact as tc " ;
$sql .= " WHERE tc.rowid = sc.fk_c_type_contact " ;
2019-11-08 15:51:54 +01:00
$sql .= " AND tc.source = 'external' AND tc.active=1 " ;
2021-08-23 17:41:11 +02:00
$sql .= " AND sc.fk_socpeople = " . (( int ) $this -> id );
2019-11-08 15:51:54 +01:00
$sql .= " AND sc.entity IN ( " . getEntity ( 'societe' ) . ')' ;
2019-09-02 14:47:32 +02:00
2019-11-08 15:51:54 +01:00
$resql = $this -> db -> query ( $sql );
2019-09-02 14:47:32 +02:00
if ( $resql ) {
2021-01-22 13:17:27 +01:00
$this -> roles = array ();
2019-09-02 14:47:32 +02:00
$num = $this -> db -> num_rows ( $resql );
if ( $num > 0 ) {
while ( $obj = $this -> db -> fetch_object ( $resql )) {
2019-11-08 15:51:54 +01:00
$transkey = " TypeContact_ " . $obj -> element . " _ " . $obj -> source . " _ " . $obj -> code ;
2019-09-02 22:01:48 +02:00
$libelle_element = $langs -> trans ( 'ContactDefault_' . $obj -> element );
2021-01-22 10:51:47 +01:00
$this -> roles [ $obj -> contactroleid ] = array ( 'id' => $obj -> rowid , 'socid' => $obj -> socid , 'element' => $obj -> element , 'source' => $obj -> source , 'code' => $obj -> code , 'label' => $libelle_element . ' - ' . ( $langs -> trans ( $transkey ) != $transkey ? $langs -> trans ( $transkey ) : $obj -> label ));
2019-09-02 14:47:32 +02:00
}
}
} else {
$error ++ ;
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> lasterror ();
$this -> errors [] = $this -> db -> lasterror ();
2019-09-02 14:47:32 +02:00
}
if ( empty ( $error )) {
return $num ;
} else {
return $error * - 1 ;
}
}
2019-09-03 17:04:42 +02:00
/**
* Get Contact roles for a thirdparty
*
2019-10-15 02:54:19 +02:00
* @ param string $element Element type
* @ return array | int Array of contact roles or - 1
2019-09-03 17:04:42 +02:00
* @ throws Exception
*/
public function getContactRoles ( $element = '' )
{
2019-11-08 15:51:54 +01:00
$tab = array ();
2019-09-03 17:04:42 +02:00
2020-02-17 12:21:07 +01:00
if ( $element == 'action' ) {
$element = 'agenda' ;
}
2019-09-03 17:04:42 +02:00
$sql = " SELECT sc.fk_socpeople as id, sc.fk_c_type_contact " ;
2019-11-08 15:51:54 +01:00
$sql .= " FROM " . MAIN_DB_PREFIX . " c_type_contact tc " ;
$sql .= " , " . MAIN_DB_PREFIX . " societe_contacts sc " ;
2022-07-19 16:08:38 +02:00
$sql .= " INNER JOIN " . MAIN_DB_PREFIX . " socpeople sp " ;
2022-08-30 16:53:14 +02:00
$sql .= " ON sc.fk_socpeople = sp.rowid AND sp.statut = 1 " ;
2021-06-09 15:36:47 +02:00
$sql .= " WHERE sc.fk_soc = " . (( int ) $this -> socid );
2019-11-08 15:51:54 +01:00
$sql .= " AND sc.fk_c_type_contact=tc.rowid " ;
2021-06-09 15:36:47 +02:00
$sql .= " AND tc.element = ' " . $this -> db -> escape ( $element ) . " ' " ;
$sql .= " AND tc.active = 1 " ;
2019-09-03 17:04:42 +02:00
2020-02-17 12:34:00 +01:00
dol_syslog ( __METHOD__ , LOG_DEBUG );
2019-11-08 15:51:54 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( $resql ) {
2019-11-08 15:51:54 +01:00
$num = $this -> db -> num_rows ( $resql );
$i = 0 ;
2021-02-23 21:16:15 +01:00
while ( $i < $num ) {
2019-09-03 17:04:42 +02:00
$obj = $this -> db -> fetch_object ( $resql );
2019-11-08 15:51:54 +01:00
$tab [] = array ( 'fk_socpeople' => $obj -> id , 'type_contact' => $obj -> fk_c_type_contact );
2019-09-03 17:04:42 +02:00
$i ++ ;
}
return $tab ;
2020-05-21 15:05:19 +02:00
} else {
2019-11-08 15:51:54 +01:00
$this -> error = $this -> db -> error ();
2019-09-03 17:04:42 +02:00
dol_print_error ( $this -> db );
return - 1 ;
}
}
2019-09-02 22:01:48 +02:00
/**
2021-01-22 10:51:47 +01:00
* Updates all roles ( default contact for companies ) according to values inside the -> roles array .
* This is called by update of contact .
2019-09-02 22:01:48 +02:00
*
* @ return float | int
2021-01-22 13:17:27 +01:00
* @ see fetchRoles ()
2019-09-02 22:01:48 +02:00
*/
public function updateRoles ()
{
global $conf ;
2019-11-08 15:51:54 +01:00
$error = 0 ;
2019-09-02 22:01:48 +02:00
2021-02-23 21:16:15 +01:00
if ( ! isset ( $this -> roles )) {
return ; // Avoid to loose roles when property not set
}
2021-01-22 13:17:27 +01:00
2019-09-02 22:01:48 +02:00
$this -> db -> begin ();
2022-03-18 12:05:59 +01:00
$sql = " DELETE FROM " . MAIN_DB_PREFIX . " societe_contacts WHERE fk_socpeople= " . (( int ) $this -> id ) . " AND entity IN ( " . getEntity ( " contact " ) . " ) " ;
2019-09-02 22:01:48 +02:00
$result = $this -> db -> query ( $sql );
if ( ! $result ) {
2019-11-08 15:51:54 +01:00
$this -> errors [] = $this -> db -> lasterror () . ' sql=' . $sql ;
2019-09-02 22:01:48 +02:00
$error ++ ;
} else {
2019-11-08 15:51:54 +01:00
if ( count ( $this -> roles ) > 0 ) {
2019-09-02 22:01:48 +02:00
foreach ( $this -> roles as $keyRoles => $valRoles ) {
2021-01-22 13:17:27 +01:00
$idrole = 0 ;
2021-01-22 14:10:08 +01:00
if ( is_array ( $valRoles )) {
2021-01-22 13:17:27 +01:00
$idrole = $valRoles [ 'id' ];
} else {
$idrole = $valRoles ;
}
2019-09-02 22:01:48 +02:00
2021-01-22 13:17:27 +01:00
$socid = 0 ;
2021-01-22 14:10:08 +01:00
if ( is_array ( $valRoles )) {
2021-01-22 13:17:27 +01:00
$socid = $valRoles [ 'socid' ];
} else {
$socid = $this -> socid ;
}
if ( $socid > 0 ) {
$sql = " INSERT INTO " . MAIN_DB_PREFIX . " societe_contacts " ;
$sql .= " (entity, " ;
$sql .= " date_creation, " ;
$sql .= " fk_soc, " ;
$sql .= " fk_c_type_contact, " ;
$sql .= " fk_socpeople) " ;
$sql .= " VALUES ( " . $conf -> entity . " , " ;
$sql .= " ' " . $this -> db -> idate ( dol_now ()) . " ', " ;
$sql .= $socid . " , " ;
$sql .= $idrole . " , " ;
$sql .= $this -> id ;
$sql .= " ) " ;
$result = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( ! $result ) {
2021-01-22 13:17:27 +01:00
$this -> errors [] = $this -> db -> lasterror () . ' sql=' . $sql ;
$error ++ ;
}
2019-09-02 22:01:48 +02:00
}
}
}
}
if ( empty ( $error )) {
$this -> db -> commit ();
return 1 ;
} else {
2019-11-08 15:51:54 +01:00
$this -> error = implode ( ' ' , $this -> errors );
2019-09-02 22:01:48 +02:00
$this -> db -> rollback ();
2019-11-08 15:51:54 +01:00
return $error * - 1 ;
2019-09-02 22:01:48 +02:00
}
}
2020-04-27 17:35:14 +02:00
/**
* Load array of prospect status
*
* @ param int $active 1 = Active only , 0 = Not active only , - 1 = All
* @ return int < 0 if KO , > 0 if OK
*/
2020-04-27 18:01:07 +02:00
public function loadCacheOfProspStatus ( $active = 1 )
2020-04-27 17:35:14 +02:00
{
global $langs ;
2020-10-31 14:32:18 +01:00
$sql = " SELECT id, code, libelle as label, picto FROM " . MAIN_DB_PREFIX . " c_stcommcontact " ;
2021-02-23 21:16:15 +01:00
if ( $active >= 0 ) {
2021-03-30 17:53:25 +02:00
$sql .= " WHERE active = " . (( int ) $active );
2021-02-23 21:16:15 +01:00
}
2020-04-27 17:48:05 +02:00
$resql = $this -> db -> query ( $sql );
$num = $this -> db -> num_rows ( $resql );
$i = 0 ;
2021-02-23 21:16:15 +01:00
while ( $i < $num ) {
2020-04-27 17:48:05 +02:00
$obj = $this -> db -> fetch_object ( $resql );
2020-10-31 14:32:18 +01:00
$this -> cacheprospectstatus [ $obj -> id ] = array ( 'id' => $obj -> id , 'code' => $obj -> code , 'label' => ( $langs -> trans ( " ST_ " . strtoupper ( $obj -> code )) == " ST_ " . strtoupper ( $obj -> code )) ? $obj -> label : $langs -> trans ( " ST_ " . strtoupper ( $obj -> code )), 'picto' => $obj -> picto );
2020-04-27 17:35:14 +02:00
$i ++ ;
}
return 1 ;
}
/**
* Return prostect level
*
* @ return string Libelle
*/
2020-04-27 18:01:07 +02:00
public function getLibProspLevel ()
2020-04-27 17:35:14 +02:00
{
2020-04-27 18:06:50 +02:00
return $this -> libProspLevel ( $this -> fk_prospectlevel );
2020-04-27 17:35:14 +02:00
}
/**
* Return label of prospect level
*
* @ param int $fk_prospectlevel Prospect level
* @ return string label of level
*/
2020-04-27 18:06:50 +02:00
public function libProspLevel ( $fk_prospectlevel )
2020-04-27 17:35:14 +02:00
{
global $langs ;
2020-10-31 14:32:18 +01:00
$lib = $langs -> trans ( " ProspectLevel " . $fk_prospectlevel );
2020-04-27 17:35:14 +02:00
// If lib not found in language file, we get label from cache/databse
2021-02-23 21:16:15 +01:00
if ( $lib == $langs -> trans ( " ProspectLevel " . $fk_prospectlevel )) {
2020-04-27 17:48:05 +02:00
$lib = $langs -> getLabelFromKey ( $this -> db , $fk_prospectlevel , 'c_prospectlevel' , 'code' , 'label' );
2020-04-27 17:35:14 +02:00
}
return $lib ;
}
/**
* Set prospect level
*
* @ param User $user Utilisateur qui definie la remise
* @ return int < 0 if KO , > 0 if OK
* @ deprecated Use update function instead
*/
2020-04-27 18:01:07 +02:00
public function setProspectLevel ( User $user )
2020-04-27 17:35:14 +02:00
{
return $this -> update ( $this -> id , $user );
}
/**
* Return status of prospect
*
* @ param int $mode 0 = libelle long , 1 = libelle court , 2 = Picto + Libelle court , 3 = Picto , 4 = Picto + Libelle long
* @ param string $label Label to use for status for added status
* @ return string Libelle
*/
2020-04-27 18:01:07 +02:00
public function getLibProspCommStatut ( $mode = 0 , $label = '' )
2020-04-27 17:35:14 +02:00
{
2020-04-27 18:01:07 +02:00
return $this -> libProspCommStatut ( $this -> stcomm_id , $mode , $label , $this -> stcomm_picto );
2020-04-27 17:35:14 +02:00
}
/**
* Return label of a given status
*
* @ param int | string $statut Id or code for prospection status
* @ param int $mode 0 = long label , 1 = short label , 2 = Picto + short label , 3 = Picto , 4 = Picto + long label , 5 = Short label + Picto
* @ param string $label Label to use for status for added status
* @ param string $picto Name of image file to show ( 'filenew' , ... )
2020-04-27 18:01:07 +02:00
* If no extension provided , we use '.png' . Image must be stored into theme / xxx / img directory .
* Example : picto . png if picto . png is stored into htdocs / theme / mytheme / img
* Example : picto . png @ mymodule if picto . png is stored into htdocs / mymodule / img
* Example : / mydir / mysubdir / picto . png if picto . png is stored into htdocs / mydir / mysubdir ( pictoisfullpath must be set to 1 )
2020-04-27 17:35:14 +02:00
* @ return string Libelle du statut
*/
2020-04-27 18:01:07 +02:00
public function libProspCommStatut ( $statut , $mode = 0 , $label = '' , $picto = '' )
2020-04-27 17:35:14 +02:00
{
global $langs ;
$langs -> load ( 'customers' );
2021-02-23 21:16:15 +01:00
if ( $mode == 2 ) {
if ( $statut == '-1' || $statut == 'ST_NO' ) {
return img_action ( $langs -> trans ( " StatusProspect-1 " ), - 1 , $picto ) . ' ' . $langs -> trans ( " StatusProspect-1 " );
} elseif ( $statut == '0' || $statut == 'ST_NEVER' ) {
return img_action ( $langs -> trans ( " StatusProspect0 " ), 0 , $picto ) . ' ' . $langs -> trans ( " StatusProspect0 " );
} elseif ( $statut == '1' || $statut == 'ST_TODO' ) {
return img_action ( $langs -> trans ( " StatusProspect1 " ), 1 , $picto ) . ' ' . $langs -> trans ( " StatusProspect1 " );
} elseif ( $statut == '2' || $statut == 'ST_PEND' ) {
return img_action ( $langs -> trans ( " StatusProspect2 " ), 2 , $picto ) . ' ' . $langs -> trans ( " StatusProspect2 " );
} elseif ( $statut == '3' || $statut == 'ST_DONE' ) {
return img_action ( $langs -> trans ( " StatusProspect3 " ), 3 , $picto ) . ' ' . $langs -> trans ( " StatusProspect3 " );
} else {
2020-10-31 14:32:18 +01:00
return img_action (( $langs -> trans ( " StatusProspect " . $statut ) != " StatusProspect " . $statut ) ? $langs -> trans ( " StatusProspect " . $statut ) : $label , 0 , $picto ) . ' ' . (( $langs -> trans ( " StatusProspect " . $statut ) != " StatusProspect " . $statut ) ? $langs -> trans ( " StatusProspect " . $statut ) : $label );
2020-04-27 17:35:14 +02:00
}
}
2021-02-23 21:16:15 +01:00
if ( $mode == 3 ) {
if ( $statut == '-1' || $statut == 'ST_NO' ) {
return img_action ( $langs -> trans ( " StatusProspect-1 " ), - 1 , $picto );
} elseif ( $statut == '0' || $statut == 'ST_NEVER' ) {
return img_action ( $langs -> trans ( " StatusProspect0 " ), 0 , $picto );
} elseif ( $statut == '1' || $statut == 'ST_TODO' ) {
return img_action ( $langs -> trans ( " StatusProspect1 " ), 1 , $picto );
} elseif ( $statut == '2' || $statut == 'ST_PEND' ) {
return img_action ( $langs -> trans ( " StatusProspect2 " ), 2 , $picto );
} elseif ( $statut == '3' || $statut == 'ST_DONE' ) {
return img_action ( $langs -> trans ( " StatusProspect3 " ), 3 , $picto );
} else {
2020-10-31 14:32:18 +01:00
return img_action (( $langs -> trans ( " StatusProspect " . $statut ) != " StatusProspect " . $statut ) ? $langs -> trans ( " StatusProspect " . $statut ) : $label , 0 , $picto );
2020-04-27 17:35:14 +02:00
}
}
2021-02-23 21:16:15 +01:00
if ( $mode == 4 ) {
if ( $statut == '-1' || $statut == 'ST_NO' ) {
return img_action ( $langs -> trans ( " StatusProspect-1 " ), - 1 , $picto ) . ' ' . $langs -> trans ( " StatusProspect-1 " );
} elseif ( $statut == '0' || $statut == 'ST_NEVER' ) {
return img_action ( $langs -> trans ( " StatusProspect0 " ), 0 , $picto ) . ' ' . $langs -> trans ( " StatusProspect0 " );
} elseif ( $statut == '1' || $statut == 'ST_TODO' ) {
return img_action ( $langs -> trans ( " StatusProspect1 " ), 1 , $picto ) . ' ' . $langs -> trans ( " StatusProspect1 " );
} elseif ( $statut == '2' || $statut == 'ST_PEND' ) {
return img_action ( $langs -> trans ( " StatusProspect2 " ), 2 , $picto ) . ' ' . $langs -> trans ( " StatusProspect2 " );
} elseif ( $statut == '3' || $statut == 'ST_DONE' ) {
return img_action ( $langs -> trans ( " StatusProspect3 " ), 3 , $picto ) . ' ' . $langs -> trans ( " StatusProspect3 " );
} else {
2020-10-31 14:32:18 +01:00
return img_action (( $langs -> trans ( " StatusProspect " . $statut ) != " StatusProspect " . $statut ) ? $langs -> trans ( " StatusProspect " . $statut ) : $label , 0 , $picto ) . ' ' . (( $langs -> trans ( " StatusProspect " . $statut ) != " StatusProspect " . $statut ) ? $langs -> trans ( " StatusProspect " . $statut ) : $label );
2020-04-27 17:35:14 +02:00
}
}
return " Error, mode/status not found " ;
}
2021-01-07 17:23:02 +01:00
/**
* Set " blacklist " mailing status
*
* @ param int $no_email 1 = Do not send mailing , 0 = Ok to recieve mailling
* @ return int < 0 if KO , > 0 if OK
*/
public function setNoEmail ( $no_email )
{
$error = 0 ;
// Update mass emailing flag into table mailing_unsubscribe
2021-02-23 21:16:15 +01:00
if ( $this -> email ) {
2021-01-07 17:23:02 +01:00
$this -> db -> begin ();
2021-02-23 21:16:15 +01:00
if ( $no_email ) {
2021-01-07 17:23:02 +01:00
$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 ) . " ' " ;
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( $resql ) {
2021-01-07 17:23:02 +01:00
$obj = $this -> db -> fetch_object ( $resql );
$noemail = $obj -> nb ;
2021-02-23 21:16:15 +01:00
if ( empty ( $noemail )) {
2021-08-23 17:41:11 +02:00
$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 ()) . " ') " ;
2021-01-07 17:23:02 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( ! $resql ) {
2021-01-07 17:23:02 +01:00
$error ++ ;
$this -> error = $this -> db -> lasterror ();
$this -> errors [] = $this -> error ;
}
}
} else {
$error ++ ;
$this -> error = $this -> db -> lasterror ();
$this -> errors [] = $this -> error ;
}
} else {
2021-08-23 17:41:11 +02:00
$sql = " DELETE FROM " . MAIN_DB_PREFIX . " mailing_unsubscribe WHERE email = ' " . $this -> db -> escape ( $this -> email ) . " ' AND entity IN ( " . getEntity ( 'mailing' , 0 ) . " ) " ;
2021-01-07 17:23:02 +01:00
$resql = $this -> db -> query ( $sql );
2021-02-23 21:16:15 +01:00
if ( ! $resql ) {
2021-01-07 17:23:02 +01:00
$error ++ ;
$this -> error = $this -> db -> lasterror ();
$this -> errors [] = $this -> error ;
}
}
if ( empty ( $error )) {
$this -> no_email = $no_email ;
$this -> db -> commit ();
return 1 ;
} else {
$this -> db -> rollback ();
return $error * - 1 ;
}
}
return 0 ;
}
/**
* get " blacklist " mailing status
* set no_email attribut to 1 or 0
*
* @ return int < 0 if KO , > 0 if OK
*/
public function getNoEmail ()
{
2021-02-23 21:16:15 +01:00
if ( $this -> email ) {
2021-01-07 17:23:02 +01:00
$sql = " SELECT COUNT(rowid) as nb FROM " . MAIN_DB_PREFIX . " mailing_unsubscribe WHERE entity IN ( " . getEntity ( 'mailing' ) . " ) AND email = ' " . $this -> db -> escape ( $this -> email ) . " ' " ;
$resql = $this -> db -> query ( $sql );
2021-01-16 14:24:47 +01:00
if ( $resql ) {
2021-01-07 17:23:02 +01:00
$obj = $this -> db -> fetch_object ( $resql );
$this -> no_email = $obj -> nb ;
return 1 ;
} else {
$this -> error = $this -> db -> lasterror ();
$this -> errors [] = $this -> error ;
return - 1 ;
}
}
return 0 ;
}
2006-02-25 00:16:35 +01:00
}