dolibarr 24.0.0-beta
suggestbooth.php
Go to the documentation of this file.
1<?php
2/* Copyright (C) 2021 Dorian Vabre <dorian.vabre@gmail.com>
3 * Copyright (C) 2024-2025 MDW <mdeweerd@users.noreply.github.com>
4 * Copyright (C) 2024-2026 Frédéric France <frederic.france@free.fr>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <https://www.gnu.org/licenses/>.
18 */
19
26if (!defined('NOLOGIN')) {
27 define("NOLOGIN", 1); // This means this output page does not require to be logged.
28}
29if (!defined('NOCSRFCHECK')) {
30 define("NOCSRFCHECK", 1); // We accept to go on this page from external web site.
31}
32if (!defined('NOIPCHECK')) {
33 define('NOIPCHECK', '1'); // Do not check IP defined into conf $dolibarr_main_restrict_ip
34}
35if (!defined('NOBROWSERNOTIF')) {
36 define('NOBROWSERNOTIF', '1');
37}
38
39
40// For MultiCompany module.
41// Do not use GETPOST here, function is not defined and define must be done before including main.inc.php
42// Because 2 entities can have the same ref.
43$entity = (!empty($_GET['entity']) ? (int) $_GET['entity'] : (!empty($_POST['entity']) ? (int) $_POST['entity'] : 1));
44if (is_numeric($entity)) {
45 define("DOLENTITY", $entity);
46}
47
48// Load Dolibarr environment
49require '../../main.inc.php';
50require_once DOL_DOCUMENT_ROOT.'/core/lib/company.lib.php';
51require_once DOL_DOCUMENT_ROOT.'/eventorganization/class/conferenceorbooth.class.php';
52require_once DOL_DOCUMENT_ROOT.'/projet/class/project.class.php';
53require_once DOL_DOCUMENT_ROOT.'/contact/class/contact.class.php';
54require_once DOL_DOCUMENT_ROOT.'/categories/class/categorie.class.php';
55require_once DOL_DOCUMENT_ROOT.'/compta/facture/class/facture.class.php';
56require_once DOL_DOCUMENT_ROOT.'/compta/facture/class/paymentterm.class.php';
57require_once DOL_DOCUMENT_ROOT.'/core/class/html.formcompany.class.php';
58require_once DOL_DOCUMENT_ROOT.'/core/lib/date.lib.php';
59
61
71// Init vars
72$errmsg = '';
73$num = 0;
74$error = 0;
75$errors = [];
76$backtopage = GETPOST('backtopage', 'alpha');
77$action = GETPOST('action', 'aZ09');
78
79$eventtype = GETPOSTINT("eventtype");
80$email = GETPOST("email");
81$societe = GETPOST("societe");
82$label = GETPOST("label");
83$note = GETPOST("note");
84$datestart = dol_mktime(0, 0, 0, GETPOSTINT('datestartmonth'), GETPOSTINT('datestartday'), GETPOSTINT('datestartyear'));
85$dateend = dol_mktime(23, 59, 59, GETPOSTINT('dateendmonth'), GETPOSTINT('dateendday'), GETPOSTINT('dateendyear'));
86$id = GETPOST('id');
87
88$project = new Project($db);
89$resultproject = $project->fetch((int) $id);
90if ($resultproject < 0) {
91 $error++;
92 $errmsg .= $project->error;
93}
94
95// Security check
96$securekeyreceived = GETPOST('securekey', 'alpha');
97$securekeytocompare = dol_hash(getDolGlobalString('EVENTORGANIZATION_SECUREKEY') . 'conferenceorbooth'.((int) $id), 'md5');
98
99if ($securekeytocompare != $securekeyreceived) {
100 print $langs->trans('MissingOrBadSecureKey');
101 exit;
102}
103
104// Load translation files
105$langs->loadLangs(array("main", "companies", "install", "other", "eventorganization"));
106
107// Initialize a technical object to manage hooks of page. Note that conf->hooks_modules contains an array of hook context
108$hookmanager->initHooks(array('publicnewmembercard', 'globalcard'));
109
110$user->loadDefaultValues();
111
112$cactioncomm = new CActionComm($db);
113$arrayofconfboothtype = $cactioncomm->liste_array('', 'id', '', 0, "module:=:'booth@eventorganization'");
114if ($arrayofconfboothtype == -1) {
115 $arrayofconfboothtype = [];
116}
117// Security check
118if (!isModEnabled('eventorganization')) {
119 httponly_accessforbidden('Module Event organization not enabled');
120}
121
122
137function llxHeaderVierge($title, $head = "", $disablejs = 0, $disablehead = 0, $arrayofjs = [], $arrayofcss = [], $ws = '') // @phan-suppress-current-line PhanRedefineFunction
138{
139 global $conf, $langs, $mysoc;
140
141 top_htmlhead($head, $title, $disablejs, $disablehead, $arrayofjs, $arrayofcss); // Show html headers
142
143 print '<body id="mainbody" class="publicnewmemberform">';
144
145 // Define urllogo
146 $urllogo = DOL_URL_ROOT.'/theme/common/login_logo.png';
147
148 if (!empty($mysoc->logo_small) && is_readable($conf->mycompany->dir_output.'/logos/thumbs/'.$mysoc->logo_small)) {
149 $urllogo = DOL_URL_ROOT.'/viewimage.php?cache=1&amp;modulepart=mycompany&amp;file='.urlencode('logos/thumbs/'.$mysoc->logo_small);
150 } elseif (!empty($mysoc->logo) && is_readable($conf->mycompany->dir_output.'/logos/'.$mysoc->logo)) {
151 $urllogo = DOL_URL_ROOT.'/viewimage.php?cache=1&amp;modulepart=mycompany&amp;file='.urlencode('logos/'.$mysoc->logo);
152 } elseif (is_readable(DOL_DOCUMENT_ROOT.'/theme/dolibarr_logo.svg')) {
153 $urllogo = DOL_URL_ROOT.'/theme/dolibarr_logo.svg';
154 }
155
156 print '<div class="center">';
157
158 // Output html code for logo
159 if ($urllogo) {
160 print '<div class="backgreypublicpayment">';
161 print '<div class="logopublicpayment">';
162 print '<img id="dolpaymentlogo" src="'.$urllogo.'"';
163 print '>';
164 print '</div>';
165 if (!getDolGlobalString('MAIN_HIDE_POWERED_BY')) {
166 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>';
167 }
168 print '</div>';
169 }
170
171 if (getDolGlobalString('PROJECT_IMAGE_PUBLIC_SUGGEST_BOOTH')) {
172 print '<div class="backimagepublicsuggestbooth">';
173 print '<img id="idPROJECT_IMAGE_PUBLIC_SUGGEST_BOOTH" src="' . getDolGlobalString('PROJECT_IMAGE_PUBLIC_SUGGEST_BOOTH').'">';
174 print '</div>';
175 }
176
177 print '</div>';
178
179 print '<div class="divmainbodylarge">';
180}
181
189function llxFooterVierge() // @phan-suppress-current-line PhanRedefineFunction
190{
191 print '</div>';
192
193 printCommonFooter('public');
194
195 print "</body>\n";
196 print "</html>\n";
197}
198
199
200
201/*
202 * Actions
203 */
204
205$parameters = array();
206// Note that $action and $object may have been modified by some hooks
207$reshook = $hookmanager->executeHooks('doActions', $parameters, $project, $action);
208if ($reshook < 0) {
209 setEventMessages($hookmanager->error, $hookmanager->errors, 'errors');
210}
211
212// Action called when page is submitted
213if (empty($reshook) && $action == 'add') { // Test on permission not required here. This is an anonymous public ssubmission. Check is done on the secureket + mitigation.
214 $error = 0;
215
216 $urlback = '';
217
218 $db->begin();
219
220 if (!GETPOST("lastname")) {
221 $error++;
222 $errmsg .= $langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("Name"))."<br>\n";
223 }
224 if (!GETPOST("email")) {
225 $error++;
226 $errmsg .= $langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("Email"))."<br>\n";
227 }
228 if (!GETPOST("country_id") && !empty((float) $project->price_booth)) {
229 $error++;
230 $errmsg .= $langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("Country"))."<br>\n";
231 }
232 if (!GETPOST("societe")) {
233 $error++;
234 $errmsg .= $langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("ThirdParty"))."<br>\n";
235 }
236 if (!GETPOST("label")) {
237 $error++;
238 $errmsg .= $langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("Label"))."<br>\n";
239 }
240 if (!GETPOST("note")) {
241 $error++;
242 $errmsg .= $langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("Note"))."<br>\n";
243 }
244 if (GETPOST("email") && !isValidEmail(GETPOST("email"))) {
245 $error++;
246 $langs->load("errors");
247 $errmsg .= $langs->trans("ErrorBadEMail", GETPOST("email"))."<br>\n";
248 }
249
250 $thirdparty = null;
251 $contact = null;
252 if (!$error) {
253 // Getting the thirdparty or creating it
254 $thirdparty = new Societe($db);
255 $resultfetchthirdparty = $thirdparty->fetch(0, $societe);
256
257 if ($resultfetchthirdparty < 0) {
258 // If an error was found
259 $error++;
260 $errmsg .= $thirdparty->error;
261 $errors = array_merge($errors, $thirdparty->errors);
262 } elseif ($resultfetchthirdparty == 0) { // No thirdparty found + a payment is expected
263 // Creation of a new thirdparty
264 $genericcompanyname = 'Unknown company';
265
266 if (!empty($societe)) {
267 $thirdparty->name = $societe;
268 } else {
269 $thirdparty->name = $genericcompanyname;
270 }
271 $thirdparty->address = GETPOST("address");
272 $thirdparty->zip = GETPOST("zipcode");
273 $thirdparty->town = GETPOST("town");
274 $thirdparty->client = $thirdparty::PROSPECT;
275 $thirdparty->fournisseur = 0;
276 $thirdparty->country_id = GETPOSTINT("country_id");
277 $thirdparty->state_id = GETPOSTINT("state_id");
278 $thirdparty->email = ($emailcompany ? $emailcompany : $email);
279
280 // Load object modCodeTiers
281 $module = getDolGlobalString('SOCIETE_CODECLIENT_ADDON', 'mod_codeclient_leopard');
282 if (substr($module, 0, 15) == 'mod_codeclient_' && substr($module, -3) == 'php') {
283 $module = substr($module, 0, dol_strlen($module) - 4);
284 }
285 $dirsociete = array_merge(array('/core/modules/societe/'), $conf->modules_parts['societe']);
286 foreach ($dirsociete as $dirroot) {
287 $res = dol_include_once($dirroot.$module.'.php');
288 if ($res) {
289 break;
290 }
291 }
292 $modCodeClient = new $module($db);
293 '@phan-var-force ModeleThirdPartyCode $modCodeClient';
296 if (empty($tmpcode) && !empty($modCodeClient->code_auto)) {
297 $tmpcode = $modCodeClient->getNextValue($thirdparty, 0);
298 }
299 $thirdparty->code_client = $tmpcode;
300 $readythirdparty = $thirdparty->create($user);
301 if ($readythirdparty < 0) {
302 $error++;
303 $errmsg .= $thirdparty->error;
304 $errors = array_merge($errors, $thirdparty->errors);
305 } else {
306 $thirdparty->country_code = getCountry($thirdparty->country_id, '2', $db, $langs);
307 $thirdparty->country = getCountry($thirdparty->country_code, '', $db, $langs);
308 }
309 }
310 // From there we have a thirdparty, now looking for the contact
311 if (!$error) {
312 $contact = new Contact($db);
313 $resultcontact = $contact->fetch(0, null, '', $email);
314 if ($resultcontact <= 0) {
315 // Need to create a contact
316 $contact->socid = $thirdparty->id;
317 $contact->lastname = (string) GETPOST("lastname", 'alpha');
318 $contact->firstname = (string) GETPOST("firstname", 'alpha');
319 $contact->address = (string) GETPOST("address", 'alpha');
320 $contact->zip = (string) GETPOST("zipcode", 'alpha');
321 $contact->town = (string) GETPOST("town", 'alpha');
322 $contact->country_id = GETPOSTINT("country_id");
323 $contact->state_id = GETPOSTINT("state_id");
324 $contact->email = $email;
325 $contact->status = 1; //Default status to Actif
326 $contact->statut = 1; //Default status to Actif
327
328 $resultcreatecontact = $contact->create($user);
329 if ($resultcreatecontact < 0) {
330 $error++;
331 $errmsg .= $contact->error;
332 }
333 }
334 }
335
336 if (!$error) {
337 // Adding supplier tag and tag from setup to thirdparty
338 $category = new Categorie($db);
339
340 $resultcategory = $category->fetch(getDolGlobalInt('EVENTORGANIZATION_CATEG_THIRDPARTY_BOOTH'));
341
342 if ($resultcategory <= 0) {
343 $error++;
344 $errmsg .= $category->error;
345 } else {
346 $resultsetcategory = $thirdparty->setCategoriesCommon(array($category->id), Categorie::TYPE_CUSTOMER, false);
347 if ($resultsetcategory < 0) {
348 $error++;
349 $errmsg .= $thirdparty->error;
350 } else {
351 $thirdparty->fournisseur = 1;
352
353 // Load object modCodeFournisseur
354 $module = getDolGlobalString('SOCIETE_CODECLIENT_ADDON', 'mod_codeclient_leopard');
355 if (substr($module, 0, 15) == 'mod_codeclient_' && substr($module, -3) == 'php') {
356 $module = substr($module, 0, dol_strlen($module) - 4);
357 }
358 $dirsociete = array_merge(array('/core/modules/societe/'), $conf->modules_parts['societe']);
359 foreach ($dirsociete as $dirroot) {
360 $res = dol_include_once($dirroot.$module.'.php');
361 if ($res) {
362 break;
363 }
364 }
365 $modCodeFournisseur = new $module($db);
366 '@phan-var-force ModeleThirdPartyCode $modCodeFournisseur';
368 if (empty($tmpcode) && !empty($modCodeFournisseur->code_auto)) {
369 $tmpcode = $modCodeFournisseur->getNextValue($thirdparty, 1);
370 }
371 $thirdparty->code_fournisseur = $tmpcode;
372
373 $res = $thirdparty->update(0, $user, 1, 1, 1);
374
375 if ($res <= 0) {
376 $error++;
377 }
378 }
379 }
380 }
381
382 if (!$error) {
383 // We have the contact and the thirdparty
384 $conforbooth = new ConferenceOrBooth($db);
385 $conforbooth->label = $label;
386 $conforbooth->fk_soc = $thirdparty->id;
387 $conforbooth->fk_project = $project->id;
388 $conforbooth->note = $note;
389 $conforbooth->fk_action = $eventtype;
390 $conforbooth->datep = $datestart;
391 $conforbooth->datep2 = $dateend;
392 $conforbooth->datec = dol_now();
393 $conforbooth->tms = dol_now();
394 $conforbooth->ip = getUserRemoteIP();
395
396 $nb_post_max = getDolGlobalInt("MAIN_SECURITY_MAX_POST_ON_PUBLIC_PAGES_BY_IP_ADDRESS", 200);
397 $now = dol_now();
398 $minmonthpost = dol_time_plus_duree($now, -1, "m");
399
400 // Calculate nb of post for IP
401 $nb_post_ip = 0;
402 if ($nb_post_max > 0) { // Calculate only if there is a limit to check
403 $sql = "SELECT COUNT(ref) as nb_confs";
404 $sql .= " FROM ".MAIN_DB_PREFIX."actioncomm";
405 $sql .= " WHERE ip = '".$db->escape($conforbooth->ip)."'";
406 $sql .= " AND datec > '".$db->idate($minmonthpost)."'";
407 $resql = $db->query($sql);
408 if ($resql) {
409 $num = $db->num_rows($resql);
410 $i = 0;
411 while ($i < $num) {
412 $i++;
413 $obj = $db->fetch_object($resql);
414 $nb_post_ip = $obj->nb_confs;
415 }
416 }
417 }
418
419 $resultconforbooth = 0;
420
421 if ($nb_post_max > 0 && $nb_post_ip >= $nb_post_max) {
422 $error++;
423 $errmsg .= $langs->trans("AlreadyTooMuchPostOnThisIPAdress");
424 array_push($conforbooth->errors, $langs->trans("AlreadyTooMuchPostOnThisIPAdress"));
425 setEventMessage($errmsg, 'errors');
426 } else {
427 $resultconforbooth = $conforbooth->create($user);
428 }
429 if ($resultconforbooth <= 0) {
430 $error++;
431 $errmsg .= $conforbooth->error;
432 } else {
433 // Adding the contact to the project
434 $resultaddcontact = $conforbooth->add_contact($contact->id, 'RESPONSIBLE');
435 if ($resultaddcontact < 0) {
436 $error++;
437 $errmsg .= $conforbooth->error;
438 } else {
439 // If this is a paying booth, we have to redirect to payment page and create an invoice
440 $facture = null;
441 if (!empty((float) $project->price_booth)) {
442 $productforinvoicerow = new Product($db);
443 $resultprod = $productforinvoicerow->fetch(getDolGlobalInt('SERVICE_BOOTH_LOCATION'));
444 if ($resultprod < 0) {
445 $error++;
446 $errmsg .= $productforinvoicerow->error;
447 } else {
448 $facture = new Facture($db);
449 $facture->type = Facture::TYPE_STANDARD;
450 $facture->socid = $thirdparty->id;
451 $facture->paye = 0;
452 $facture->date = dol_now();
453 $facture->cond_reglement_id = $contact->cond_reglement_id;
454 $facture->fk_project = $project->id;
455
456 if (empty($facture->cond_reglement_id)) {
457 $paymenttermstatic = new PaymentTerm($contact->db);
458 $facture->cond_reglement_id = $paymenttermstatic->getDefaultId();
459 if (empty($facture->cond_reglement_id)) {
460 $error++;
461 $contact->error = 'ErrorNoPaymentTermRECEPFound';
462 $contact->errors[] = $contact->error;
463 }
464 }
465 $resultfacture = $facture->create($user);
466 if ($resultfacture <= 0) {
467 $contact->setErrorsFromObject($facture);
468 $error++;
469 } else {
470 $db->commit();
471 $facture->add_object_linked($conforbooth->element, $conforbooth->id);
472 }
473 }
474
475 if (!$error && is_object($facture)) {
476 // Add line to draft invoice
477 $vattouse = get_default_tva($mysoc, $thirdparty, $productforinvoicerow->id);
478 $result = $facture->addline($langs->trans("BoothLocationFee", $conforbooth->label, dol_print_date($conforbooth->datep, '%d/%m/%y %H:%M:%S'), dol_print_date($conforbooth->datep2, '%d/%m/%y %H:%M:%S')), (float) $project->price_booth, 1, $vattouse, 0, 0, $productforinvoicerow->id, 0, dol_now(), '', 0, 0, 0, 'HT', 0, 1);
479 if ($result <= 0) {
480 $contact->setErrorsFromObject($facture);
481 $error++;
482 }
483 /*if (!$error) {
484 $valid = true;
485 $sourcetouse = 'boothlocation';
486 $reftouse = $facture->id;
487 $redirection = $dolibarr_main_url_root.'/public/payment/newpayment.php?source='.$sourcetouse.'&ref='.$reftouse.'&booth='.$conforbooth->id;
488 if (getDolGlobalString('PAYMENT_SECURITY_TOKEN')) {
489 $redirection .= '&securekey='.dol_hash(getDolGlobalString('PAYMENT_SECURITY_TOKEN') . $sourcetouse . $reftouse, '2'); // Use the source in the hash to avoid duplicates if the references are identical
490 }
491 header("Location: ".$redirection);
492 exit;
493 }*/
494 }
495 } else {
496 // If no price has been set for the booth, we confirm it as suggested and we update
497 $conforbooth->status = ConferenceOrBooth::STATUS_SUGGESTED;
498 $conforbooth->update($user);
499 }
500 }
501 }
502 }
503 }
504
505 if (!$error && is_object($thirdparty)) {
506 $db->commit();
507
508 // Sending mail
509 require_once DOL_DOCUMENT_ROOT.'/core/class/CMailFile.class.php';
510 include_once DOL_DOCUMENT_ROOT.'/core/class/html.formmail.class.php';
511 $formmail = new FormMail($db);
512 // Set output language
513 $outputlangs = new Translate('', $conf);
514 $outputlangs->setDefaultLang(empty($thirdparty->default_lang) ? $mysoc->default_lang : $thirdparty->default_lang);
515 // Load traductions files required by page
516 $outputlangs->loadLangs(array("main", "members", "eventorganization"));
517 // Get email content from template
518 $arraydefaultmessage = null;
519
520 $labeltouse = getDolGlobalInt('EVENTORGANIZATION_TEMPLATE_EMAIL_ASK_BOOTH');
521 if (!empty($labeltouse)) {
522 $arraydefaultmessage = $formmail->getEMailTemplate($db, 'conferenceorbooth', $user, $outputlangs, $labeltouse, 1, '');
523 }
524
525 $subject = '';
526 $msg = '';
527 if (!empty($labeltouse) && is_object($arraydefaultmessage) && $arraydefaultmessage->id > 0) {
528 $subject = $arraydefaultmessage->topic;
529 $msg = $arraydefaultmessage->content;
530 }
531
532 $substitutionarray = getCommonSubstitutionArray($outputlangs, 0, null, $thirdparty);
533 complete_substitutions_array($substitutionarray, $outputlangs, $project);
534
535 $subjecttosend = make_substitutions($subject, $substitutionarray, $outputlangs);
536 $texttosend = make_substitutions($msg, $substitutionarray, $outputlangs);
537
538 $sendto = $thirdparty->email;
539 $from = getDolGlobalString('MAILING_EMAIL_FROM');
540 $urlback = $_SERVER["REQUEST_URI"];
541 $trackid = 'proj'.$project->id;
542
543 $ishtml = dol_textishtml($texttosend); // May contain urls
544
545 $mailfile = new CMailFile($subjecttosend, $sendto, $from, $texttosend, array(), array(), array(), '', '', 0, $ishtml ? 1 : 0, '', '', $trackid);
546
547 $result = $mailfile->sendfile();
548 if ($result) {
549 dol_syslog("EMail sent to ".$sendto, LOG_DEBUG, 0, '_payment');
550 } else {
551 dol_syslog("Failed to send EMail to ".$sendto, LOG_ERR, 0, '_payment');
552 }
553
554 $securekeyurl = dol_hash(getDolGlobalString('EVENTORGANIZATION_SECUREKEY') . 'conferenceorbooth'.((int) $id), 'md5');
555 $redirection = $dolibarr_main_url_root.'/public/eventorganization/subscriptionok.php?id='.$id.'&securekey='.$securekeyurl;
556 header("Location: ".$redirection);
557 exit;
558 } else {
559 $db->rollback();
560 }
561}
562
563
564/*
565 * View
566 */
567
568$form = new Form($db);
569$formcompany = new FormCompany($db);
570
571llxHeaderVierge($langs->trans("NewSuggestionOfBooth"));
572
573
574print '<div align="center">';
575print '<div id="divsubscribe">';
576
577print '<br>';
578
579// Sub banner
580print '<div class="center subscriptionformbanner subbanner justify margintoponly paddingtop marginbottomonly padingbottom">';
581print load_fiche_titre($langs->trans("NewSuggestionOfBooth"), '', '', 0, '', 'center');
582// Welcome message
583print '<span class="opacitymedium">'.$langs->trans("EvntOrgRegistrationWelcomeMessage").'</span>';
584print '<br>';
585// Title
586print '<span class="eventlabel large">'.dol_escape_htmltag($project->title . ' '. $project->label).'</span><br>';
587print '</div>';
588
589
590// Help text
591print '<div class="justify subscriptionformhelptext">';
592
593if ($project->date_start_event || $project->date_end_event) {
594 print '<br><span class="fa fa-calendar pictofixedwidth opacitymedium"></span>';
595}
596if ($project->date_start_event) {
597 $format = 'day';
598 $tmparray = dol_getdate($project->date_start_event, false, '');
599 if ($tmparray['hours'] || $tmparray['minutes'] || $tmparray['minutes']) {
600 $format = 'dayhour';
601 }
602 print dol_print_date($project->date_start_event, $format);
603}
604if ($project->date_start_event && $project->date_end_event) {
605 print ' - ';
606}
607if ($project->date_end_event) {
608 $format = 'day';
609 $tmparray = dol_getdate($project->date_end_event, false, '');
610 if ($tmparray['hours'] || $tmparray['minutes'] || $tmparray['minutes']) {
611 $format = 'dayhour';
612 }
613 print dol_print_date($project->date_end_event, $format);
614}
615if ($project->date_start_event || $project->date_end_event) {
616 print '<br>';
617}
618if ($project->location) {
619 print '<span class="fa fa-map-marked-alt pictofixedwidth opacitymedium"></span>'.dol_escape_htmltag($project->location).'<br>';
620}
621if ($project->note_public) {
622 print '<br><!-- note public --><span class="opacitymedium">'.dol_htmlentitiesbr($project->note_public).'</span><br>';
623}
624
625print '</div>';
626
627print '<br>';
628
629
630dol_htmloutput_errors($errmsg, $errors);
631
632// Print form
633print '<form action="'.$_SERVER["PHP_SELF"].'" method="POST" name="newmember">'."\n";
634print '<input type="hidden" name="token" value="'.newToken().'" / >';
635print '<input type="hidden" name="entity" value="'.$entity.'" />';
636print '<input type="hidden" name="action" value="add" />';
637print '<input type="hidden" name="id" value="'.$id.'" />';
638print '<input type="hidden" name="securekey" value="'.$securekeyreceived.'" />';
639
640
641print '<br><span class="opacitymedium">'.$langs->trans("FieldsWithAreMandatory", '*').'</span><br>';
642//print $langs->trans("FieldsWithIsForPublic",'**').'<br>';
643
644print dol_get_fiche_head();
645
646print '<script type="text/javascript">
647jQuery(document).ready(function () {
648 jQuery(document).ready(function () {
649 jQuery("#selectcountry_id").change(function() {
650 document.newmember.action.value="create";
651 document.newmember.submit();
652 });
653 });
654});
655</script>';
656
657print '<table class="border" summary="form to subscribe" id="tablesubscribe">'."\n";
658
659// Name
660print '<tr><td><label for="lastname">'.$langs->trans("Lastname").'<span class="star">*</span></label></td>';
661print '<td colspan="3"><input name="lastname" id="lastname" type="text" class="maxwidth100onsmartphone" maxlength="80" value="'.dol_escape_htmltag(GETPOST("lastname", 'alpha') ? GETPOST("lastname", 'alpha') : $object->lastname).'" autofocus="autofocus"></td>';
662print '</tr>';
663// Email
664print '<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')).'"></td></tr>'."\n";
665// Company
666print '<tr id="trcompany" class="trcompany"><td>'.$langs->trans("Company").'<span class="star">*</span>';
667print ' </td><td><input type="text" name="societe" class="minwidth150" value="'.dol_escape_htmltag(GETPOST('societe')).'"></td></tr>'."\n";
668// Address
669print '<tr><td>'.$langs->trans("Address").'</td><td>'."\n";
670print '<textarea name="address" id="address" wrap="soft" class="quatrevingtpercent" rows="'.ROWS_3.'">'.dol_escape_htmltag(GETPOST('address', 'restricthtml'), 0, 1).'</textarea></td></tr>'."\n";
671// Zip / Town
672print '<tr><td>'.$langs->trans('Zip').' / '.$langs->trans('Town').'</td><td>';
673print $formcompany->select_ziptown(GETPOST('zipcode'), 'zipcode', array('town', 'selectcountry_id', 'state_id'), 6, 1);
674print ' / ';
675print $formcompany->select_ziptown(GETPOST('town'), 'town', array('zipcode', 'selectcountry_id', 'state_id'), 0, 1);
676print '</td></tr>';
677// Country
678print '<tr><td>'.$langs->trans('Country');
679print '<span class="star">*</span>';
680print '</td><td>';
681$country_id = GETPOST('country_id');
682if (!$country_id && getDolGlobalString('MEMBER_NEWFORM_FORCECOUNTRYCODE')) {
683 $country_id = getCountry($conf->global->MEMBER_NEWFORM_FORCECOUNTRYCODE, '2', $db, $langs);
684}
685if (!$country_id && !empty($conf->geoipmaxmind->enabled)) {
686 $country_code = dol_user_country();
687 //print $country_code;
688 if ($country_code) {
689 $new_country_id = getCountry($country_code, '3', $db, $langs);
690 //print 'xxx'.$country_code.' - '.$new_country_id;
691 if ($new_country_id) {
692 $country_id = $new_country_id;
693 }
694 }
695}
696$country_code = getCountry($country_id, '2', $db, $langs);
697print $form->select_country($country_id, 'country_id');
698print '</td></tr>';
699// State
700if (!getDolGlobalString('SOCIETE_DISABLE_STATE')) {
701 print '<tr><td>'.$langs->trans('State').'</td><td>';
702 if ($country_code) {
703 print $formcompany->select_state(GETPOSTINT("state_id"), $country_code);
704 } else {
705 print '';
706 }
707 print '</td></tr>';
708}
709// Type of event
710print '<tr><td>'.$langs->trans("Format").'<span class="star">*</span></td>'."\n";
711print '<td>'.Form::selectarray('eventtype', $arrayofconfboothtype, $eventtype, 1).'</td>';
712// Label
713print '<tr><td>'.$langs->trans("LabelOfBooth").'<span class="star">*</span></td>'."\n";
714print '</td><td><input type="text" name="label" class="minwidth150" value="'.dol_escape_htmltag(GETPOST('label')).'"></td></tr>'."\n";
715// Note
716print '<tr><td>'.$langs->trans("Description").'<span class="star">*</span></td>'."\n";
717print '<td><textarea name="note" id="note" wrap="soft" class="quatrevingtpercent" rows="'.ROWS_3.'">'.dol_escape_htmltag(GETPOST('note', 'restricthtml'), 0, 1).'</textarea></td></tr>'."\n";
718
719print "</table>\n";
720
721print dol_get_fiche_end();
722
723
724// Show all action buttons
725print '<div class="center">';
726print '<br>';
727print '<input type="submit" value="'.$langs->trans("SuggestBooth").'" name="suggestbooth" id="suggestbooth" class="button">';
728print '</div>';
729print '<br><br>';
730
731
732print "</form>\n";
733print "<br>";
734print '</div></div>';
735
736
738
739$db->close();
$id
Support class for third parties, contacts, members, users or resources.
Definition account.php:47
if(! $sortfield) if(! $sortorder) $object
Definition account.php:100
global $dolibarr_main_url_root
llxFooterVierge()
Footer function.
Class to manage different types of events.
Class to send emails (with attachments or not) Usage: $mailfile = new CMailFile($subject,...
Class to manage categories.
Class for ConferenceOrBooth.
Class to manage contact/addresses.
Class to manage invoices.
const TYPE_STANDARD
Standard invoice.
Class to build HTML component for third parties management Only common components are here.
Class to manage generation of HTML components Only common components must be here.
Class to manage a HTML form to send a unitary email Usage: $formail = new FormMail($db) $formmail->pr...
Class to manage payment terms records in dictionary.
Class to manage products or services.
Class to manage projects.
Class to manage third parties objects (customers, suppliers, prospects...)
Class to manage translations.
getCountry($searchkey, $withcode='', $dbtouse=null, $outputlangs=null, $entconv=1, $searchlabel='')
Return country label, code or id from an id, code or label.
global $mysoc
dol_time_plus_duree($time, $duration_value, $duration_unit, $ruleforendofmonth=0)
Add a delay to a date.
Definition date.lib.php:126
if(!isModEnabled('ai')||!getDolGlobalString('AI_ASSISTANT_ENABLED')) global $conf
The main.inc.php has been included so the following variable are now defined:
if(!isModEnabled('ai')||!getDolGlobalString('AI_ASSISTANT_ENABLED')) global $db
API class for accounts.
dol_now($mode='gmt')
Return date for now.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed information (by default a local PHP server timestamp) Rep...
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, $morecssdiv='')
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_strlen($string, $stringencoding='UTF-8')
Make a strlen call.
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.
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...
dol_textishtml($msg, $option=0)
Return if a text is a html content.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false, $decorate=0)
Output date in a string format according to outputlangs (or langs if not defined).
getUserRemoteIP($trusted=0)
Return the real IP of remote user.
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='', $morecssonpicto='widthpictotitle')
Load a title with picto.
isValidEmail($address, $acceptsupervisorkey=0, $acceptuserkey=0)
Return true if email syntax is ok.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
isModEnabled($module)
Is Dolibarr module enabled.
get_default_tva(Societe $thirdparty_seller, Societe $thirdparty_buyer, $idprod=0, $idprodfournprice=0)
Function that return vat rate of a product line (according to seller, buyer and product vat rate) VAT...
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_getdate($timestamp, $fast=false, $forcetimezone='')
Return an array with locale date info.
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...
print $langs trans("Show") . '< td style="' . $timeColor . '" align="center"> s</td > badge status0 badge status4 badge status3 Error badge status8< td align="center">< span class="badge ' . $badge . '"></span ></td >< td align="center">< a href="#" class="button button-small" onclick="openLogModal(this)" data-req="' . dol_escape_htmltag($reqSafe) . '" data-res="' . dol_escape_htmltag($resSafe) . '" data-err="' . dol_escape_htmltag($errSafe) . '">< span class="fa fa-search-plus"></span ></a ></td ></tr >< tr >< td colspan="' . $colspan . '" class="opacitymedium"></td ></tr ></table ></div ></form > logModal none logModal none s a JSON string
buildzip.php
top_htmlhead($head, $title='', $disablejs=0, $disablehead=0, $arrayofjs=array(), $arrayofcss=array(), $disableforlogin=0, $disablenofollow=0, $disablenoindex=0)
Output html header of a page.
httponly_accessforbidden($message='1', $http_response_code=403, $stringalreadysanitized=0)
Show a message to say access is forbidden and stop program.
dol_hash($chain, $type='0', $nosalt=0, $mode=0)
Returns a hash (non reversible encryption) of a string.
if($arrayofconfboothtype==-1) if(!isModEnabled( 'eventorganization')) llxHeaderVierge($title, $head="", $disablejs=0, $disablehead=0, $arrayofjs=[], $arrayofcss=[], $ws='')
Show header for new member.