31if (!defined(
'NOLOGIN')) {
34if (!defined(
'NOCSRFCHECK')) {
35 define(
"NOCSRFCHECK", 1);
37if (!defined(
'NOIPCHECK')) {
38 define(
'NOIPCHECK',
'1');
40if (!defined(
'NOBROWSERNOTIF')) {
41 define(
'NOBROWSERNOTIF',
'1');
48$entity = (!empty($_GET[
'entity']) ? (int) $_GET[
'entity'] : (!empty($_POST[
'entity']) ? (int) $_POST[
'entity'] : 1));
49if (is_numeric($entity)) {
50 define(
"DOLENTITY", $entity);
54require
'../../main.inc.php';
55require_once DOL_DOCUMENT_ROOT.
'/core/lib/company.lib.php';
56require_once DOL_DOCUMENT_ROOT.
'/projet/class/project.class.php';
57require_once DOL_DOCUMENT_ROOT.
'/core/class/extrafields.class.php';
58require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formcompany.class.php';
59require_once DOL_DOCUMENT_ROOT.
'/core/lib/date.lib.php';
64$backtopage =
GETPOST(
'backtopage',
'alpha');
65$action =
GETPOST(
'action',
'aZ09');
76$langs->loadLangs(array(
"members",
"companies",
"install",
"other",
"projects"));
79 print $langs->trans(
"Form for public lead registration has not been enabled");
84$hookmanager->initHooks(array(
'publicnewleadcard',
'globalcard'));
90$user->loadDefaultValues();
93if (empty(
$conf->project->enabled)) {
109function llxHeaderVierge($title, $head =
"", $disablejs = 0, $disablehead = 0, $arrayofjs = [], $arrayofcss = [])
111 global
$conf, $langs, $mysoc;
113 top_htmlhead($head, $title, $disablejs, $disablehead, $arrayofjs, $arrayofcss);
115 print
'<body id="mainbody" class="publicnewmemberform">';
118 $urllogo = DOL_URL_ROOT.
'/theme/common/login_logo.png';
120 if (!empty($mysoc->logo_small) && is_readable(
$conf->mycompany->dir_output.
'/logos/thumbs/'.$mysoc->logo_small)) {
121 $urllogo = DOL_URL_ROOT.
'/viewimage.php?cache=1&modulepart=mycompany&file='.urlencode(
'logos/thumbs/'.$mysoc->logo_small);
122 } elseif (!empty($mysoc->logo) && is_readable(
$conf->mycompany->dir_output.
'/logos/'.$mysoc->logo)) {
123 $urllogo = DOL_URL_ROOT.
'/viewimage.php?cache=1&modulepart=mycompany&file='.urlencode(
'logos/'.$mysoc->logo);
124 } elseif (is_readable(DOL_DOCUMENT_ROOT.
'/theme/dolibarr_logo.svg')) {
125 $urllogo = DOL_URL_ROOT.
'/theme/dolibarr_logo.svg';
128 print
'<div class="center">';
132 print
'<div class="backgreypublicpayment">';
133 print
'<div class="logopublicpayment">';
134 print
'<img id="dolpaymentlogo" src="'.$urllogo.
'"';
138 print
'<div class="poweredbypublicpayment opacitymedium right"><a class="poweredbyhref" href="https://www.dolibarr.org?utm_medium=website&utm_source=poweredby" target="dolibarr" rel="noopener">'.$langs->trans(
"PoweredBy").
'<br><img class="poweredbyimg" src="'.DOL_URL_ROOT.
'/theme/dolibarr_logo.svg" width="80px"></a></div>';
144 print
'<div class="backimagepublicnewlead">';
145 print
'<img id="idPROJECT_IMAGE_PUBLIC_NEWLEAD" src="' .
getDolGlobalString(
'PROJECT_IMAGE_PUBLIC_NEWLEAD').
'">';
151 print
'<div class="divmainbodylarge">';
175$parameters = array();
177$reshook = $hookmanager->executeHooks(
'doActions', $parameters,
$object, $action);
183if (empty($reshook) && $action ==
'add') {
189 if (!
GETPOST(
'lastname',
'alpha')) {
191 $errmsg .= $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Lastname")).
"<br>\n";
193 if (!
GETPOST(
'firstname',
'alpha')) {
195 $errmsg .= $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Firstname")).
"<br>\n";
197 if (!
GETPOST(
'email',
'alpha')) {
199 $errmsg .= $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Email")).
"<br>\n";
201 if (!
GETPOST(
'description',
'alpha')) {
203 $errmsg .= $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Message")).
"<br>\n";
207 $langs->load(
"errors");
208 $errmsg .= $langs->trans(
"ErrorBadEMail",
GETPOST(
'email',
'alpha')).
"<br>\n";
211 $defaultoppstatus =
getDolGlobalInt(
'PROJECT_DEFAULT_OPPORTUNITY_STATUS_FOR_ONLINE_LEAD');
212 if (empty($defaultoppstatus)) {
214 $langs->load(
"errors");
215 $errmsg .= $langs->trans(
"ErrorModuleSetupNotComplete", $langs->transnoentitiesnoconv(
"Project")).
"<br>\n";
221 $thirdparty =
new Societe($db);
225 $result = $thirdparty->fetch(0,
'',
'',
'',
'',
'',
'',
'',
'',
'',
GETPOST(
'email',
'alpha'));
227 $proj->socid = $thirdparty->id;
230 if (
GETPOST(
'societe',
'alpha')) {
231 $thirdparty->name =
GETPOST(
'societe',
'alpha');
236 $thirdparty->email =
GETPOST(
'email',
'alpha');
237 $thirdparty->address =
GETPOST(
'address',
'alpha');
238 $thirdparty->zip =
GETPOST(
'zip',
'int');
239 $thirdparty->town =
GETPOST(
'town',
'alpha');
240 $thirdparty->country_id =
GETPOSTINT(
'country_id');
241 $thirdparty->state_id =
GETPOSTINT(
'state_id');
242 $thirdparty->client = $thirdparty::PROSPECT;
243 $thirdparty->code_client =
'auto';
244 $thirdparty->code_fournisseur =
'auto';
247 $extrafields->fetch_name_optionals_label($thirdparty->table_element);
248 $ret = $extrafields->setOptionalsFromPost(
null, $thirdparty,
'', 1);
251 $errmsg = ($extrafields->error ? $extrafields->error.
'<br>' :
'').implode(
'<br>', $extrafields->errors);
255 $result = $thirdparty->create($user);
258 $errmsg = ($thirdparty->error ? $thirdparty->error.
'<br>' :
'').implode(
'<br>', $thirdparty->errors);
260 $proj->socid = $thirdparty->id;
276 $dirmodels = array_merge(array(
'/'), (array)
$conf->modules_parts[
'models']);
277 foreach ($dirmodels as $reldir) {
278 $file =
dol_buildpath($reldir.
"core/modules/project/".$modele.
'.php', 0);
279 if (file_exists($file)) {
281 $classname = $modele;
286 if ($filefound && !empty($classname)) {
288 if (class_exists($classname)) {
289 $modProject =
new $classname();
290 '@phan-var-force ModeleNumRefProjects $modProject';
292 $defaultref = $modProject->getNextValue($thirdparty,
$object);
296 if (is_numeric($defaultref) && $defaultref <= 0) {
300 if (empty($defaultref)) {
301 $defaultref =
'PJ'.dol_print_date(
dol_now(),
'dayrfc');
304 if ($visibility ===
"1") {
306 } elseif ($visibility ===
"0") {
308 } elseif (empty($visibility)) {
312 $proj->ref = $defaultref;
313 $proj->statut = $proj::STATUS_DRAFT;
314 $proj->status = $proj::STATUS_DRAFT;
315 $proj->usage_opportunity = 1;
316 $proj->title = $langs->trans(
"LeadFromPublicForm");
317 $proj->description =
GETPOST(
"description",
"alphanohtml");
318 $proj->opp_status = $defaultoppstatus;
319 $proj->fk_opp_status = $defaultoppstatus;
322 $nb_post_max =
getDolGlobalInt(
"MAIN_SECURITY_MAX_POST_ON_PUBLIC_PAGES_BY_IP_ADDRESS", 200);
326 if ($nb_post_max > 0) {
327 $sql =
"SELECT COUNT(rowid) as nb_projets";
328 $sql .=
" FROM ".MAIN_DB_PREFIX.
"projet";
329 $sql .=
" WHERE ip = '".$db->escape($proj->ip).
"'";
330 $sql .=
" AND datec > '".$db->idate($minmonthpost).
"'";
331 $resql = $db->query($sql);
333 $num = $db->num_rows($resql);
337 $obj = $db->fetch_object($resql);
338 $nb_post_ip = $obj->nb_projets;
344 $extrafields->fetch_name_optionals_label($proj->table_element);
345 $ret = $extrafields->setOptionalsFromPost(
null, $proj);
350 if ($nb_post_max > 0 && $nb_post_ip >= $nb_post_max) {
352 $errmsg = $langs->trans(
"AlreadyTooMuchPostOnThisIPAdress");
353 array_push($proj->errors, $langs->trans(
"AlreadyTooMuchPostOnThisIPAdress"));
357 $result = $proj->create($user);
359 require_once DOL_DOCUMENT_ROOT.
'/core/class/CMailFile.class.php';
367 include_once DOL_DOCUMENT_ROOT.
'/core/class/html.formmail.class.php';
371 $outputlangs->setDefaultLang(empty(
$object->thirdparty->default_lang) ? $mysoc->default_lang :
$object->thirdparty->default_lang);
373 $outputlangs->loadLangs(array(
"main",
"members",
"projects"));
375 $arraydefaultmessage =
null;
378 if (!empty($labeltouse)) {
379 $arraydefaultmessage = $formmail->getEMailTemplate($db,
'project', $user, $outputlangs, 0, 1, $labeltouse);
382 if (!empty($labeltouse) && is_object($arraydefaultmessage) && $arraydefaultmessage->id > 0) {
383 $subject = $arraydefaultmessage->topic;
384 $msg = $arraydefaultmessage->content;
386 if (empty($labeltosue)) {
387 $appli = $mysoc->name;
389 $labeltouse =
'['.$appli.
'] '.$langs->trans(
"YourMessage");
390 $msg = $langs->trans(
"YourMessageHasBeenReceived");
397 if ($subjecttosend && $texttosend) {
398 $moreinheader =
'X-Dolibarr-Info: send_an_email by public/lead/new.php'.
"\r\n";
400 $result =
$object->sendEmail($texttosend, $subjecttosend, array(), array(), array(),
"",
"", 0, -1,
'', $moreinheader);
408 if (!empty($backtopage)) {
409 $urlback = $backtopage;
414 $urlback = $_SERVER[
"PHP_SELF"].
"?action=added&token=".
newToken();
417 if (!empty($entity)) {
418 $urlback .=
'&entity='.$entity;
421 dol_syslog(
"project lead ".$proj->ref.
" has been created, we redirect to ".$urlback);
424 $errmsg .= $proj->error.
'<br>'.implode(
'<br>', $proj->errors);
434 header(
"Location: ".$urlback);
443if (empty($reshook) && $action ==
'added') {
448 print
'<div class="center">';
449 print $langs->trans(
"NewLeadbyWeb");
462$form =
new Form($db);
465$extrafields->fetch_name_optionals_label(
$object->table_element);
470print
load_fiche_titre($langs->trans(
"NewContact"),
'',
'', 0,
'',
'center');
473print
'<div align="center">';
474print
'<div id="divsubscribe">';
476print
'<div class="center subscriptionformhelptext opacitymedium justify">';
480 print $langs->trans(
"FormForNewLeadDesc",
getDolGlobalString(
"MAIN_INFO_SOCIETE_MAIL")).
"<br>\n";
487print
'<form action="'.$_SERVER[
"PHP_SELF"].
'" method="POST" name="newlead">'.
"\n";
488print
'<input type="hidden" name="token" value="'.newToken().
'" / >';
489print
'<input type="hidden" name="entity" value="'.$entity.
'" />';
490print
'<input type="hidden" name="action" value="add" />';
494print
'<br><span class="opacitymedium">'.$langs->trans(
"FieldsWithAreMandatory",
'*').
'</span><br>';
499print
'<script type="text/javascript">
500jQuery(document).ready(function () {
501 jQuery(document).ready(function () {
502 jQuery("#selectcountry_id").change(function() {
503 document.newlead.action.value="create";
504 document.newlead.submit();
511print
'<table class="border" summary="form to subscribe" id="tablesubscribe">'.
"\n";
514print
'<tr><td>'.$langs->trans(
"Lastname").
' <span class="star">*</span></td><td><input type="text" name="lastname" class="minwidth150" value="'.
dol_escape_htmltag(
GETPOST(
'lastname')).
'" required></td></tr>'.
"\n";
516print
'<tr><td>'.$langs->trans(
"Firstname").
' <span class="star">*</span></td><td><input type="text" name="firstname" class="minwidth150" value="'.
dol_escape_htmltag(
GETPOST(
'firstname')).
'" required></td></tr>'.
"\n";
518print
'<tr><td>'.$langs->trans(
"Email").
' <span class="star">*</span></td><td><input type="text" name="email" maxlength="255" class="minwidth150" value="'.
dol_escape_htmltag(
GETPOST(
'email')).
'" required></td></tr>'.
"\n";
520print
'<tr id="trcompany" class="trcompany"><td>'.$langs->trans(
"Company").
'</td><td><input type="text" name="societe" class="minwidth150" value="'.
dol_escape_htmltag(
GETPOST(
'societe')).
'"></td></tr>'.
"\n";
522print
'<tr><td>'.$langs->trans(
"Address").
'</td><td>'.
"\n";
523print
'<textarea name="address" id="address" wrap="soft" class="quatrevingtpercent" rows="'.ROWS_2.
'">'.
dol_escape_htmltag(
GETPOST(
'address',
'restricthtml'), 0, 1).
'</textarea></td></tr>'.
"\n";
525print
'<tr><td>'.$langs->trans(
'Zip').
' / '.$langs->trans(
'Town').
'</td><td>';
526print $formcompany->select_ziptown(
GETPOST(
'zipcode'),
'zipcode', array(
'town',
'selectcountry_id',
'state_id'), 6, 1);
528print $formcompany->select_ziptown(
GETPOST(
'town'),
'town', array(
'zipcode',
'selectcountry_id',
'state_id'), 0, 1);
531print
'<tr><td>'.$langs->trans(
'Country').
'</td><td>';
532$country_id =
GETPOST(
'country_id');
534 $country_id =
getCountry(
$conf->global->PROJECT_NEWFORM_FORCECOUNTRYCODE,
'2', $db, $langs);
536if (!$country_id && !empty(
$conf->geoipmaxmind->enabled)) {
540 $new_country_id =
getCountry($country_code,
'3', $db, $langs);
542 if ($new_country_id) {
543 $country_id = $new_country_id;
547$country_code =
getCountry($country_id,
'2', $db, $langs);
548print $form->select_country($country_id,
'country_id');
552 print
'<tr><td>'.$langs->trans(
'State').
'</td><td>';
554 print $formcompany->select_state(
GETPOSTINT(
"state_id"), $country_code);
562$parameters[
'tpl_context'] =
'public';
563include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_add.tpl.php';
566print
'<td class="tdtop">'.$langs->trans(
"Message").
' <span class="star">*</span></td>';
567print
'<td class="tdtop"><textarea name="description" id="description" wrap="soft" class="quatrevingtpercent" rows="'.ROWS_5.
'" required>'.
dol_escape_htmltag(
GETPOST(
'description',
'restricthtml'), 0, 1).
'</textarea></td>';
575print
'<div class="center">';
576print
'<input type="submit" value="'.$langs->trans(
"Submit").
'" id="submitsave" class="button">';
577if (!empty($backtopage)) {
578 print
' <input type="submit" value="'.$langs->trans(
"Cancel").
'" id="submitcancel" class="button button-cancel">';
if( $user->socid > 0) if(! $user->hasRight('accounting', 'chartofaccount')) $object
Class to manage projects.
Class to manage third parties objects (customers, suppliers, prospects...)
Class to manage translations.
llxHeaderVierge($title, $head="", $disablejs=0, $disablehead=0, $arrayofjs=[], $arrayofcss=[])
Show header for new prospect.
llxFooterVierge()
Show footer for new societe.
getCountry($searchkey, $withcode='', $dbtouse=null, $outputlangs=null, $entconv=1, $searchlabel='')
Return country label, code or id from an id, code or label.
dol_time_plus_duree($time, $duration_value, $duration_unit, $ruleforendofmonth=0)
Add a delay to a date.
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0)
Show tabs of a record.
dol_user_country()
Return country code for current user.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
setEventMessage($mesgs, $style='mesgs', $noduplicate=0, $attop=0)
Set event message in dol_events session object.
printCommonFooter($zone='private')
Print common footer : conf->global->MAIN_HTML_FOOTER js for switch of menu hider js for conf->global-...
dol_now($mode='auto')
Return date for now.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
if(!function_exists( 'dol_getprefix')) dol_include_once($relpath, $classname='')
Make an include_once using default root and alternate root if it fails.
newToken()
Return the value of token currently saved into session with name 'newtoken'.
dolGetFirstLastname($firstname, $lastname, $nameorder=-1)
Return firstname and lastname in correct order.
complete_substitutions_array(&$substitutionarray, $outputlangs, $object=null, $parameters=null, $callfunc="completesubstitutionarray")
Complete the $substitutionarray with more entries coming from external module that had set the "subst...
make_substitutions($text, $substitutionarray, $outputlangs=null, $converttextinhtmlifnecessary=0)
Make substitution into a text string, replacing keys with vals from $substitutionarray (oldval=>newva...
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_buildpath($path, $type=0, $returnemptyifnotfound=0)
Return path of url or filesystem.
getCommonSubstitutionArray($outputlangs, $onlykey=0, $exclude=null, $object=null, $include=null)
Return array of possible common substitutions.
isValidEmail($address, $acceptsupervisorkey=0, $acceptuserkey=0)
Return true if email syntax is ok.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
getUserRemoteIP()
Return the IP of remote user.
dol_htmloutput_errors($mesgstring='', $mesgarray=array(), $keepembedded=0)
Print formatted error messages to output (Used to show messages on html output).
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0, $cleanalsojavascript=0)
Returns text escaped for inclusion in HTML alt or title or value tags, or into values of HTML input f...
top_htmlhead($head, $title='', $disablejs=0, $disablehead=0, $arrayofjs=array(), $arrayofcss=array(), $disableforlogin=0, $disablenofollow=0, $disablenoindex=0)
Output html header of a page.
global $conf
The following vars must be defined: $type2label $form $conf, $lang, The following vars may also be de...
httponly_accessforbidden($message='1', $http_response_code=403, $stringalreadysanitized=0)
Show a message to say access is forbidden and stop program.