index.php 94 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649
  1. <?php
  2. /* Copyright (C) 2016-2017 Laurent Destailleur <eldy@users.sourceforge.net>
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License as published by
  6. * the Free Software Foundation; either version 3 of the License, or
  7. * (at your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  16. */
  17. /**
  18. * \file htdocs/website/index.php
  19. * \ingroup website
  20. * \brief Page to website view/edit
  21. */
  22. define('NOSCANPOSTFORINJECTION',1);
  23. define('NOSTYLECHECK',1);
  24. require '../main.inc.php';
  25. require_once DOL_DOCUMENT_ROOT.'/core/lib/admin.lib.php';
  26. require_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';
  27. require_once DOL_DOCUMENT_ROOT.'/core/lib/website.lib.php';
  28. require_once DOL_DOCUMENT_ROOT.'/core/class/doleditor.class.php';
  29. require_once DOL_DOCUMENT_ROOT.'/core/class/html.formadmin.class.php';
  30. require_once DOL_DOCUMENT_ROOT.'/core/class/html.formwebsite.class.php';
  31. require_once DOL_DOCUMENT_ROOT.'/core/class/html.formother.class.php';
  32. require_once DOL_DOCUMENT_ROOT.'/website/class/website.class.php';
  33. require_once DOL_DOCUMENT_ROOT.'/website/class/websitepage.class.php';
  34. $langs->loadLangs(array("admin","other","website"));
  35. if (! $user->admin) accessforbidden();
  36. if (! ((GETPOST('testmenuhider','int') || ! empty($conf->global->MAIN_TESTMENUHIDER)) && empty($conf->global->MAIN_OPTIMIZEFORTEXTBROWSER)))
  37. {
  38. $conf->dol_hide_leftmenu = 1; // Force hide of left menu.
  39. }
  40. $error=0;
  41. $websitekey=GETPOST('website', 'alpha');
  42. $page=GETPOST('page', 'alpha');
  43. $pageid=GETPOST('pageid', 'int');
  44. $pageref=GETPOST('pageref', 'aZ09');
  45. $action=GETPOST('action','aZ09');
  46. $confirm=GETPOST('confirm','alpha');
  47. $cancel=GETPOST('cancel','alpha');
  48. $type_container=GETPOST('WEBSITE_TYPE_CONTAINER', 'alpha');
  49. $section_dir = GETPOST('section_dir', 'alpha');
  50. $file_manager = GETPOST('file_manager', 'alpha');
  51. if (GETPOST('deletesite','alpha')) { $action='deletesite'; }
  52. if (GETPOST('delete','alpha')) { $action='delete'; }
  53. if (GETPOST('preview','alpha')) $action='preview';
  54. if (GETPOST('createsite','alpha')) { $action='createsite'; }
  55. if (GETPOST('createcontainer','alpha')) { $action='createcontainer'; }
  56. if (GETPOST('editcss','alpha')) { $action='editcss'; }
  57. if (GETPOST('editmenu','alpha')) { $action='editmenu'; }
  58. if (GETPOST('setashome','alpha')) { $action='setashome'; }
  59. if (GETPOST('editmeta','alpha')) { $action='editmeta'; }
  60. if (GETPOST('editsource','alpha')) { $action='editsource'; }
  61. if (GETPOST('editcontent','alpha')) { $action='editcontent'; }
  62. if (GETPOST('exportsite','alpha')) { $action='exportsite'; }
  63. if (GETPOST('importsite','alpha')) { $action='importsite'; }
  64. if (GETPOST('createfromclone','alpha')) { $action='createfromclone'; }
  65. if (GETPOST('createpagefromclone','alpha')) { $action='createpagefromclone'; }
  66. if (empty($action) && $file_manager) $action='file_manager';
  67. // Load variable for pagination
  68. $limit = GETPOST('limit','int')?GETPOST('limit','int'):$conf->liste_limit;
  69. $sortfield = GETPOST("sortfield",'alpha');
  70. $sortorder = GETPOST("sortorder",'alpha');
  71. $page = GETPOST("page",'int');
  72. if (empty($page) || $page == -1) { $page = 0; } // If $page is not defined, or '' or -1
  73. $offset = $limit * $page;
  74. $pageprev = $page - 1;
  75. $pagenext = $page + 1;
  76. //if (! $sortfield) $sortfield='name';
  77. //if (! $sortorder) $sortorder='ASC';
  78. if (empty($action)) $action='preview';
  79. $object=new Website($db);
  80. $objectpage=new WebsitePage($db);
  81. $object->fetchAll(); // Init $object->records
  82. // If website not defined, we take first found
  83. if (empty($websitekey))
  84. {
  85. foreach($object->records as $key => $valwebsite)
  86. {
  87. $websitekey=$valwebsite->ref;
  88. break;
  89. }
  90. }
  91. if ($websitekey)
  92. {
  93. $res = $object->fetch(0, $websitekey);
  94. }
  95. $website = $object;
  96. if ($pageid < 0) $pageid = 0;
  97. if (($pageid > 0 || $pageref) && $action != 'addcontainer')
  98. {
  99. $res = $objectpage->fetch($pageid, ($object->id > 0 ? $object->id : null), $pageref);
  100. //var_dump($res);exit;
  101. //if ($res == 0) // Page ref not found, we check in alias
  102. //{
  103. // $res = $objectpage->fetch($pageid, ($object->id > 0 ? $object->id : null), $pageref);
  104. //}
  105. // Check if pageid is inside the new website, if not we reset param pageid
  106. if ($object->id > 0 && ($objectpage->fk_website != $object->id))
  107. {
  108. $res = $objectpage->fetch(0, $object->id, '');;
  109. if ($res == 0) // Page was not found, we reset it
  110. {
  111. $objectpage=new WebsitePage($db);
  112. }
  113. }
  114. $pageid = $objectpage->id;
  115. }
  116. global $dolibarr_main_data_root;
  117. $pathofwebsite=$dolibarr_main_data_root.'/website/'.$websitekey;
  118. $filehtmlheader=$pathofwebsite.'/htmlheader.html';
  119. $filecss=$pathofwebsite.'/styles.css.php';
  120. $filejs=$pathofwebsite.'/javascript.js.php';
  121. $filerobot=$pathofwebsite.'/robots.txt';
  122. $filehtaccess=$pathofwebsite.'/.htaccess';
  123. $filetpl=$pathofwebsite.'/page'.$pageid.'.tpl.php';
  124. $fileindex=$pathofwebsite.'/index.php';
  125. // Define $urlwithroot
  126. $urlwithouturlroot=preg_replace('/'.preg_quote(DOL_URL_ROOT,'/').'$/i','',trim($dolibarr_main_url_root));
  127. $urlwithroot=$urlwithouturlroot.DOL_URL_ROOT; // This is to use external domain name found into config file
  128. //$urlwithroot=DOL_MAIN_URL_ROOT; // This is to use same domain name than current
  129. $permtouploadfile = $user->rights->website->write;
  130. $diroutput = $conf->medias->multidir_output[$conf->entity];
  131. $relativepath=$section_dir;
  132. $upload_dir = $diroutput.'/'.$relativepath;
  133. $htmlheadercontentdefault = '';
  134. $htmlheadercontentdefault.='<link rel="stylesheet" id="google-fonts-css" href="//fonts.googleapis.com/css?family=Open+Sans:300,400,700" />'."\n";
  135. $htmlheadercontentdefault.='<link rel="stylesheet" id="font-wasesome-css" href="//cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" />'."\n";
  136. $htmlheadercontentdefault.='<script src="//cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>'."\n";
  137. $htmlheadercontentdefault.='<script src="//cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>'."\n";
  138. $htmlheadercontentdefault.='<script src="//cdnjs.cloudflare.com/ajax/libs/tether/1.4.0/js/tether.min.js"></script>'."\n";
  139. $htmlheadercontentdefault.='<script src="//cdnjs.cloudflare.com/ajax/libs/popper.js/1.13.0/umd/popper.min.js"></script>'."\n";
  140. $htmlheadercontentdefault.='<script src="//cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.0.0-beta.2/js/bootstrap.min.js"></script>'."\n";
  141. $htmlheadercontentdefault.='<!--'."\n";
  142. $htmlheadercontentdefault.='<script src="/document.php?modulepart=medias&file=css/myfile.css"></script>'."\n";
  143. $htmlheadercontentdefault.='<script src="/document.php?modulepart=medias&file=js/myfile.js"></script>'."\n";
  144. $htmlheadercontentdefault.='-->'."\n";
  145. /*
  146. * Actions
  147. */
  148. $backtopage=$_SERVER["PHP_SELF"].'?file_manager=1&website='.$websitekey.'&pageid='.$pageid; // used after a confirm_deletefile into actions_linkedfiles.inc.php
  149. include DOL_DOCUMENT_ROOT.'/core/actions_linkedfiles.inc.php';
  150. if ($action == 'renamefile') $action='file_manager'; // After actions_linkedfiles, if action were renamefile, we set it to 'file_manager'
  151. if ($action == 'seteditinline')
  152. {
  153. dolibarr_set_const($db, 'WEBSITE_EDITINLINE', 1);
  154. header("Location: ".$_SERVER["PHP_SELF"].'?website='.GETPOST('website','alphanohtml').'&pageid='.GETPOST('pageid','int'));
  155. exit;
  156. }
  157. if ($action == 'unseteditinline')
  158. {
  159. dolibarr_del_const($db, 'WEBSITE_EDITINLINE');
  160. header("Location: ".$_SERVER["PHP_SELF"].'?website='.GETPOST('website','alphanohtml').'&pageid='.GETPOST('pageid','int'));
  161. exit;
  162. }
  163. // Add directory
  164. /*
  165. if ($action == 'adddir' && $permtouploadfile)
  166. {
  167. $ecmdir->ref = 'NOTUSEDYET';
  168. $ecmdir->label = GETPOST("label");
  169. $ecmdir->description = GETPOST("desc");
  170. //$id = $ecmdir->create($user);
  171. if ($id > 0)
  172. {
  173. header("Location: ".$_SERVER["PHP_SELF"]);
  174. exit;
  175. }
  176. else
  177. {
  178. setEventMessages('Error '.$langs->trans($ecmdir->error), null, 'errors');
  179. $action = "createcontainer";
  180. }
  181. clearstatcache();
  182. }
  183. */
  184. if (GETPOST('refreshsite','alpha')) // If we change the site, we reset the pageid and cancel addsite action.
  185. {
  186. $pageid=0;
  187. if ($action == 'addsite') $action = 'preview';
  188. }
  189. if (GETPOST('refreshpage','alpha') && ! in_array($action, array('updatecss'))) $action='preview';
  190. // Add site
  191. if ($action == 'addsite')
  192. {
  193. $db->begin();
  194. if (! $error && ! GETPOST('WEBSITE_REF','alpha'))
  195. {
  196. $error++;
  197. $langs->load("errors");
  198. setEventMessages($langs->transnoentities("ErrorFieldRequired", $langs->transnoentities("Ref")), null, 'errors');
  199. }
  200. if (! $error && ! preg_match('/^[a-z0-9_\-\.]+$/i', GETPOST('WEBSITE_REF','alpha')))
  201. {
  202. $error++;
  203. $langs->load("errors");
  204. setEventMessages($langs->transnoentities("ErrorFieldCanNotContainSpecialCharacters", $langs->transnoentities("Ref")), null, 'errors');
  205. }
  206. if (! $error)
  207. {
  208. $tmpobject=new Website($db);
  209. $tmpobject->ref = GETPOST('WEBSITE_REF','alpha');
  210. $tmpobject->description = GETPOST('WEBSITE_DESCRIPTION','alpha');
  211. $tmpobject->virtualhost = GETPOST('WEBSITE_VIRTUALHOST','alpha');
  212. $result = $tmpobject->create($user);
  213. if ($result <= 0)
  214. {
  215. $error++;
  216. setEventMessages($tmpobject->error, $tmpobject->errors, 'errors');
  217. }
  218. }
  219. if (! $error)
  220. {
  221. $db->commit();
  222. setEventMessages($langs->trans("SiteAdded", $object->ref), null, 'mesgs');
  223. $action='';
  224. header("Location: ".$_SERVER["PHP_SELF"].'?website='.$tmpobject->ref);
  225. exit;
  226. }
  227. else
  228. {
  229. $db->rollback();
  230. $action='createsite';
  231. }
  232. if (! $error)
  233. {
  234. $action = 'preview';
  235. $id = $object->id;
  236. }
  237. }
  238. // Add page/container
  239. if ($action == 'addcontainer')
  240. {
  241. dol_mkdir($pathofwebsite);
  242. $db->begin();
  243. $objectpage->fk_website = $object->id;
  244. if (GETPOST('fetchexternalurl','alpha'))
  245. {
  246. $urltograb=GETPOST('externalurl','alpha');
  247. $grabimages=GETPOST('grabimages','alpha');
  248. $grabimagesinto=GETPOST('grabimagesinto','alpha');
  249. //var_dump($grabimages);exit;
  250. }
  251. if ($urltograb)
  252. {
  253. include_once DOL_DOCUMENT_ROOT.'/core/lib/geturl.lib.php';
  254. // Clean url to grab, so url can be
  255. // http://www.example.com/ or http://www.example.com/dir1/ or http://www.example.com/dir1/aaa
  256. $urltograbwithoutdomainandparam = preg_replace('/^https?:\/\/[^\/]+\/?/i', '', $urltograb);
  257. $urltograbwithoutdomainandparam = preg_replace('/\?.*$/', '', $urltograbwithoutdomainandparam);
  258. if (empty($urltograbwithoutdomainandparam) && ! preg_match('/\/$/', $urltograb))
  259. {
  260. $urltograb.='/';
  261. }
  262. $pageurl = dol_sanitizeFileName(preg_replace('/[\/\.]/','-', preg_replace('/\/+$/', '', $urltograbwithoutdomainandparam)));
  263. $urltograbdirwithoutslash = dirname($urltograb.'.');
  264. $urltograbdirrootwithoutslash = getRootURLFromURL($urltograbdirwithoutslash);
  265. // Exemple, now $urltograbdirwithoutslash is https://www.dolimed.com/screenshots
  266. // and $urltograbdirrootwithoutslash is https://www.dolimed.com
  267. // Check pageurl is not already used
  268. if ($pageurl)
  269. {
  270. $tmpwebsitepage = new WebsitePage($db);
  271. $result = $tmpwebsitepage->fetch(0, $object->id, $pageurl);
  272. if ($result > 0)
  273. {
  274. setEventMessages($langs->trans("AliasPageAlreadyExists", $pageurl), null, 'errors');
  275. $error++;
  276. $action='createcontainer';
  277. }
  278. }
  279. if (! $error)
  280. {
  281. $tmp = getURLContent($urltograb);
  282. if ($tmp['curl_error_no'])
  283. {
  284. $error++;
  285. setEventMessages('Error getting '.$urltograb.': '.$tmp['curl_error_msg'], null, 'errors');
  286. $action='createcontainer';
  287. }
  288. elseif ($tmp['http_code'] != '200')
  289. {
  290. $error++;
  291. setEventMessages('Error getting '.$urltograb.': '.$tmp['http_code'], null, 'errors');
  292. $action='createcontainer';
  293. }
  294. else
  295. {
  296. // Remove comments
  297. $tmp['content'] = removeHtmlComment($tmp['content']);
  298. preg_match('/<head>(.*)<\/head>/is', $tmp['content'], $reg);
  299. $head = $reg[1];
  300. $objectpage->type_container = 'page';
  301. $objectpage->pageurl = $pageurl;
  302. if (empty($objectpage->pageurl))
  303. {
  304. $tmpdomain = getDomainFromURL($urltograb);
  305. $objectpage->pageurl=$tmpdomain.'-home';
  306. }
  307. $objectpage->aliasalt = '';
  308. if (preg_match('/^(\d+)\-/', basename($urltograb), $reg)) $objectpage->aliasalt = $reg[1];
  309. if (preg_match('/<title>(.*)<\/title>/ims', $head, $regtmp))
  310. {
  311. $objectpage->title = $regtmp[1];
  312. }
  313. if (preg_match('/<meta name="title"[^"]+content="([^"]+)"/ims', $head, $regtmp))
  314. {
  315. if (empty($objectpage->title)) $objectpage->title = $regtmp[1]; // If title not found into <title>, we get it from <meta title>
  316. }
  317. if (preg_match('/<meta name="description"[^"]+content="([^"]+)"/ims', $head, $regtmp))
  318. {
  319. $objectpage->description = $regtmp[1];
  320. }
  321. if (preg_match('/<meta name="keywords"[^"]+content="([^"]+)"/ims', $head, $regtmp))
  322. {
  323. $objectpage->keywords = $regtmp[1];
  324. }
  325. if (preg_match('/<html\s+lang="([^"]+)"/ims', $tmp['content'], $regtmp))
  326. {
  327. $tmplang=explode('-', $regtmp[1]);
  328. $objectpage->lang = $tmplang[0].($tmplang[1] ? '_'.strtoupper($tmplang[1]) : '');
  329. }
  330. $tmp['content'] = preg_replace('/\s*<meta name="generator"[^"]+content="([^"]+)"\s*\/?>/ims', '', $tmp['content']);
  331. $objectpage->content = $tmp['content'];
  332. $objectpage->content = preg_replace('/^.*<body(\s[^>]*)*>/ims', '', $objectpage->content);
  333. $objectpage->content = preg_replace('/<\/body(\s[^>]*)*>.*$/ims', '', $objectpage->content);
  334. $absoluteurlinaction=$urltograbdirwithoutslash;
  335. // TODO Replace 'action="$urltograbdirwithoutslash' into action="/"
  336. // TODO Replace 'action="$urltograbdirwithoutslash..."' into action="..."
  337. // TODO Replace 'a href="$urltograbdirwithoutslash' into a href="/"
  338. // TODO Replace 'a href="$urltograbdirwithoutslash..."' into a href="..."
  339. // Now loop to fetch all css files. Include them inline into header of page
  340. $objectpage->htmlheader = $tmp['content'];
  341. $objectpage->htmlheader = preg_replace('/^.*<head(\s[^>]*)*>/ims', '', $objectpage->htmlheader);
  342. $objectpage->htmlheader = preg_replace('/<\/head(\s[^>]*)*>.*$/ims', '', $objectpage->htmlheader);
  343. $objectpage->htmlheader = preg_replace('/<base(\s[^>]*)*>\n*/ims', '', $objectpage->htmlheader);
  344. $objectpage->htmlheader = preg_replace('/<meta http-equiv="content-type"([^>]*)*>\n*/ims', '', $objectpage->htmlheader);
  345. $objectpage->htmlheader = preg_replace('/<meta name="robots"([^>]*)*>\n*/ims', '', $objectpage->htmlheader);
  346. $objectpage->htmlheader = preg_replace('/<meta name="title"([^>]*)*>\n*/ims', '', $objectpage->htmlheader);
  347. $objectpage->htmlheader = preg_replace('/<meta name="description"([^>]*)*>\n*/ims', '', $objectpage->htmlheader);
  348. $objectpage->htmlheader = preg_replace('/<meta name="keywords"([^>]*)*>\n*/ims', '', $objectpage->htmlheader);
  349. $objectpage->htmlheader = preg_replace('/<meta name="generator"([^>]*)*>\n*/ims', '', $objectpage->htmlheader);
  350. //$objectpage->htmlheader = preg_replace('/<meta name="verify-v1[^>]*>\n*/ims', '', $objectpage->htmlheader);
  351. //$objectpage->htmlheader = preg_replace('/<meta name="msvalidate.01[^>]*>\n*/ims', '', $objectpage->htmlheader);
  352. $objectpage->htmlheader = preg_replace('/<title>[^<]*<\/title>\n*/ims', '', $objectpage->htmlheader);
  353. $objectpage->htmlheader = preg_replace('/<link[^>]*rel="shortcut[^>]*>\n/ims', '', $objectpage->htmlheader);
  354. // Now loop to fetch JS
  355. $tmp = $objectpage->htmlheader;
  356. preg_match_all('/<script([^\.>]+)src=["\']([^"\'>]+)["\']([^>]*)><\/script>/i', $objectpage->htmlheader, $regs);
  357. foreach ($regs[0] as $key => $val)
  358. {
  359. dol_syslog("We will grab the resource found into script tag ".$regs[2][$key]);
  360. $linkwithoutdomain = $regs[2][$key];
  361. if (preg_match('/^\//', $regs[2][$key]))
  362. {
  363. $urltograbbis = $urltograbdirrootwithoutslash.$regs[2][$key]; // We use dirroot
  364. }
  365. else
  366. {
  367. $urltograbbis = $urltograbdirwithoutslash.'/'.$regs[2][$key]; // We use dir of grabbed file
  368. }
  369. //$filetosave = $conf->medias->multidir_output[$conf->entity].'/css/'.$object->ref.'/'.$objectpage->pageurl.(preg_match('/^\//', $regs[2][$key])?'':'/').$regs[2][$key];
  370. if (preg_match('/^http/', $regs[2][$key]))
  371. {
  372. $urltograbbis = $regs[2][$key];
  373. $linkwithoutdomain = preg_replace('/^https?:\/\/[^\/]+\//i', '', $regs[2][$key]);
  374. //$filetosave = $conf->medias->multidir_output[$conf->entity].'/css/'.$object->ref.'/'.$objectpage->pageurl.(preg_match('/^\//', $linkwithoutdomain)?'':'/').$linkwithoutdomain;
  375. }
  376. //print $domaintograb.' - '.$domaintograbbis.' - '.$urltograbdirwithoutslash.' - ';
  377. //print $linkwithoutdomain.' - '.$urltograbbis."<br>\n";
  378. // Test if this is an external URL of grabbed web site. If yes, we do not load resource
  379. $domaintograb = getDomainFromURL($urltograbdirwithoutslash);
  380. $domaintograbbis = getDomainFromURL($urltograbbis);
  381. if ($domaintograb != $domaintograbbis) continue;
  382. /*
  383. $tmpgeturl = getURLContent($urltograbbis);
  384. if ($tmpgeturl['curl_error_no'])
  385. {
  386. $error++;
  387. setEventMessages('Error getting '.$urltograbbis.': '.$tmpgeturl['curl_error_msg'], null, 'errors');
  388. $action='createcontainer';
  389. }
  390. elseif ($tmpgeturl['http_code'] != '200')
  391. {
  392. $error++;
  393. setEventMessages('Error getting '.$urltograbbis.': '.$tmpgeturl['http_code'], null, 'errors');
  394. $action='createcontainer';
  395. }
  396. else
  397. {
  398. dol_mkdir(dirname($filetosave));
  399. $fp = fopen($filetosave, "w");
  400. fputs($fp, $tmpgeturl['content']);
  401. fclose($fp);
  402. if (! empty($conf->global->MAIN_UMASK))
  403. @chmod($file, octdec($conf->global->MAIN_UMASK));
  404. }
  405. */
  406. //$filename = 'image/'.$object->ref.'/'.$objectpage->pageurl.(preg_match('/^\//', $linkwithoutdomain)?'':'/').$linkwithoutdomain;
  407. $tmp = preg_replace('/'.preg_quote($regs[0][$key],'/').'/i', '', $tmp);
  408. }
  409. $objectpage->htmlheader = trim($tmp)."\n";
  410. // Now loop to fetch CSS
  411. $pagecsscontent = "\n".'<style>'."\n";
  412. preg_match_all('/<link([^\.>]+)href=["\']([^"\'>]+\.css[^"\'>]*)["\']([^>]*)>/i', $objectpage->htmlheader, $regs);
  413. foreach ($regs[0] as $key => $val)
  414. {
  415. dol_syslog("We will grab the resource found into link tag ".$regs[2][$key]);
  416. $linkwithoutdomain = $regs[2][$key];
  417. if (preg_match('/^\//', $regs[2][$key]))
  418. {
  419. $urltograbbis = $urltograbdirrootwithoutslash.$regs[2][$key]; // We use dirroot
  420. }
  421. else
  422. {
  423. $urltograbbis = $urltograbdirwithoutslash.'/'.$regs[2][$key]; // We use dir of grabbed file
  424. }
  425. //$filetosave = $conf->medias->multidir_output[$conf->entity].'/css/'.$object->ref.'/'.$objectpage->pageurl.(preg_match('/^\//', $regs[2][$key])?'':'/').$regs[2][$key];
  426. if (preg_match('/^http/', $regs[2][$key]))
  427. {
  428. $urltograbbis = $regs[2][$key];
  429. $linkwithoutdomain = preg_replace('/^https?:\/\/[^\/]+\//i', '', $regs[2][$key]);
  430. //$filetosave = $conf->medias->multidir_output[$conf->entity].'/css/'.$object->ref.'/'.$objectpage->pageurl.(preg_match('/^\//', $linkwithoutdomain)?'':'/').$linkwithoutdomain;
  431. }
  432. //print $domaintograb.' - '.$domaintograbbis.' - '.$urltograbdirwithoutslash.' - ';
  433. //print $linkwithoutdomain.' - '.$urltograbbis."<br>\n";
  434. // Test if this is an external URL of grabbed web site. If yes, we do not load resource
  435. $domaintograb = getDomainFromURL($urltograbdirwithoutslash);
  436. $domaintograbbis = getDomainFromURL($urltograbbis);
  437. if ($domaintograb != $domaintograbbis) continue;
  438. $tmpgeturl = getURLContent($urltograbbis);
  439. if ($tmpgeturl['curl_error_no'])
  440. {
  441. $error++;
  442. setEventMessages('Error getting '.$urltograbbis.': '.$tmpgeturl['curl_error_msg'], null, 'errors');
  443. $action='createcontainer';
  444. }
  445. elseif ($tmpgeturl['http_code'] != '200')
  446. {
  447. $error++;
  448. setEventMessages('Error getting '.$urltograbbis.': '.$tmpgeturl['http_code'], null, 'errors');
  449. $action='createcontainer';
  450. }
  451. else
  452. {
  453. //dol_mkdir(dirname($filetosave));
  454. //$fp = fopen($filetosave, "w");
  455. //fputs($fp, $tmpgeturl['content']);
  456. //fclose($fp);
  457. //if (! empty($conf->global->MAIN_UMASK))
  458. // @chmod($file, octdec($conf->global->MAIN_UMASK));
  459. // $filename = 'image/'.$object->ref.'/'.$objectpage->pageurl.(preg_match('/^\//', $linkwithoutdomain)?'':'/').$linkwithoutdomain;
  460. $pagecsscontent.='/* Content of file '.$urltograbbis.' */'."\n";
  461. getAllImages($object, $objectpage, $urltograbbis, $tmpgeturl['content'], $action, 1, $grabimages, $grabimagesinto);
  462. $pagecsscontent.=$tmpgeturl['content']."\n";
  463. $objectpage->htmlheader = preg_replace('/'.preg_quote($regs[0][$key],'/').'\n*/ims', '', $objectpage->htmlheader);
  464. }
  465. }
  466. $pagecsscontent.='</style>';
  467. //var_dump($pagecsscontent);
  468. //print dol_escape_htmltag($tmp);exit;
  469. $objectpage->htmlheader .= trim($pagecsscontent)."\n";
  470. // Now loop to fetch all images into page
  471. $tmp = $objectpage->content;
  472. getAllImages($object, $objectpage, $urltograb, $tmp, $action, 1, $grabimages, $grabimagesinto);
  473. // Normalize links href to Dolibarr internal naming
  474. $tmp = preg_replace('/a href="\/([^\/"]+)\/([^\/"]+)"/', 'a href="/\1-\2.php"', $tmp);
  475. $tmp = preg_replace('/a href="\/([^\/"]+)\/([^\/"]+)\/([^\/"]+)"/', 'a href="/\1-\2-\3.php"', $tmp);
  476. $tmp = preg_replace('/a href="\/([^\/"]+)\/([^\/"]+)\/([^\/"]+)\/([^\/"]+)"/', 'a href="/\1-\2-\3-\4.php"', $tmp);
  477. //print dol_escape_htmltag($tmp);exit;
  478. $objectpage->content = $tmp;
  479. $objectpage->grabbed_from = $urltograb;
  480. }
  481. }
  482. }
  483. else
  484. {
  485. $objectpage->title = GETPOST('WEBSITE_TITLE','alpha');
  486. $objectpage->type_container = GETPOST('WEBSITE_TYPE_CONTAINER','alpha');
  487. $objectpage->pageurl = GETPOST('WEBSITE_PAGENAME','alpha');
  488. $objectpage->aliasalt = GETPOST('WEBSITE_ALIASALT','alpha');
  489. $objectpage->description = GETPOST('WEBSITE_DESCRIPTION','alpha');
  490. $objectpage->keywords = GETPOST('WEBSITE_KEYWORDS','alpha');
  491. $objectpage->lang = GETPOST('WEBSITE_LANG','aZ09');
  492. $objectpage->htmlheader = GETPOST('htmlheader','none');
  493. $substitutionarray=array();
  494. $substitutionarray['__WEBSITE_CREATE_BY__']=$user->getFullName($langs);
  495. $sample = GETPOST('sample','alpha');
  496. if (empty($sample)) $sample='empty';
  497. $pathtosample = DOL_DOCUMENT_ROOT.'/website/page-sample-'.$sample.'.html';
  498. // Init content with content into pagetemplate.html, blogposttempltate.html, ...
  499. $objectpage->content = make_substitutions(@file_get_contents($pathtosample), $substitutionarray);
  500. }
  501. if (! $error)
  502. {
  503. if (empty($objectpage->pageurl))
  504. {
  505. $langs->load("errors");
  506. setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("WEBSITE_PAGENAME")), null, 'errors');
  507. $error++;
  508. $action='createcontainer';
  509. }
  510. else if (! preg_match('/^[a-z0-9\-\_]+$/i', $objectpage->pageurl))
  511. {
  512. $langs->load("errors");
  513. setEventMessages($langs->transnoentities("ErrorFieldCanNotContainSpecialCharacters", $langs->transnoentities('WEBSITE_PAGENAME')), null, 'errors');
  514. $error++;
  515. $action='createcontainer';
  516. }
  517. if (empty($objectpage->title))
  518. {
  519. $langs->load("errors");
  520. setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("WEBSITE_TITLE")), null, 'errors');
  521. $error++;
  522. $action='createcontainer';
  523. }
  524. }
  525. if (! $error)
  526. {
  527. $res = $objectpage->create($user);
  528. if ($res <= 0)
  529. {
  530. $error++;
  531. setEventMessages($objectpage->error, $objectpage->errors, 'errors');
  532. $action='createcontainer';
  533. }
  534. }
  535. if (! $error)
  536. {
  537. if (! empty($objectpage->content))
  538. {
  539. $filealias=$pathofwebsite.'/'.$objectpage->pageurl.'.php';
  540. $filetpl=$pathofwebsite.'/page'.$objectpage->id.'.tpl.php';
  541. // Save page alias
  542. $result=dolSavePageAlias($filealias, $object, $objectpage);
  543. if (! $result) setEventMessages('Failed to write file '.$filealias, null, 'errors');
  544. // Save page of content
  545. $result=dolSavePageContent($filetpl, $object, $objectpage);
  546. if ($result)
  547. {
  548. setEventMessages($langs->trans("Saved"), null, 'mesgs');
  549. //header("Location: ".$_SERVER["PHP_SELF"].'?website='.$websitekey.'&pageid='.$pageid);
  550. //exit;
  551. }
  552. else
  553. {
  554. setEventMessages('Failed to write file '.$filetpl, null, 'errors');
  555. //header("Location: ".$_SERVER["PHP_SELF"].'?website='.$websitekey.'&pageid='.$pageid);
  556. //exit;
  557. }
  558. }
  559. }
  560. if (! $error)
  561. {
  562. $db->commit();
  563. setEventMessages($langs->trans("PageAdded", $objectpage->pageurl), null, 'mesgs');
  564. $action='';
  565. }
  566. else
  567. {
  568. $db->rollback();
  569. }
  570. if (! $error)
  571. {
  572. $pageid = $objectpage->id;
  573. // To generate the CSS, robot and htmlheader file.
  574. // Check symlink to medias and restore it if ko
  575. $pathtomedias=DOL_DATA_ROOT.'/medias';
  576. $pathtomediasinwebsite=$pathofwebsite.'/medias';
  577. if (! is_link(dol_osencode($pathtomediasinwebsite)))
  578. {
  579. dol_syslog("Create symlink for ".$pathtomedias." into name ".$pathtomediasinwebsite);
  580. dol_mkdir(dirname($pathtomediasinwebsite)); // To be sure dir for website exists
  581. $result = symlink($pathtomedias, $pathtomediasinwebsite);
  582. }
  583. if (! dol_is_file($filehtmlheader))
  584. {
  585. $htmlheadercontent ="<html>\n";
  586. $htmlheadercontent.=$htmlheadercontentdefault;
  587. $htmlheadercontent.="</html>";
  588. $result=dolSaveHtmlHeader($filehtmlheader, $htmlheadercontent);
  589. }
  590. if (! dol_is_file($filecss))
  591. {
  592. $csscontent = "/* CSS content (all pages) */\nbody.bodywebsite { margin: 0; font-family: 'Open Sans', sans-serif; }\n.bodywebsite h1 { margin-top: 0; margin-bottom: 0; padding: 10px;}";
  593. $result=dolSaveCssFile($filecss, $csscontent);
  594. }
  595. if (! dol_is_file($filejs))
  596. {
  597. $jscontent = "/* JS content (all pages) */\n";
  598. $result=dolSaveJsFile($filejs, $jscontent);
  599. }
  600. if (! dol_is_file($filerobot))
  601. {
  602. $robotcontent = "# Robot file. Generated with Dolibarr\nUser-agent: *\nAllow: /public/\nDisallow: /administrator/";
  603. $result=dolSaveRobotFile($filerobot, $robotcontent);
  604. }
  605. if (! dol_is_file($filehtaccess))
  606. {
  607. $htaccesscontent = "# Order allow,deny\n# Deny from all";
  608. $result=dolSaveHtaccessFile($filehtaccess, $htaccesscontent);
  609. }
  610. $action = 'preview';
  611. }
  612. }
  613. // Delete site
  614. if ($action == 'deletesite')
  615. {
  616. $error = 0;
  617. $db->begin();
  618. $res = $object->fetch(0, $websitekey);
  619. $website = $object;
  620. if ($res > 0)
  621. {
  622. $res = $object->delete($user);
  623. if ($res <= 0)
  624. {
  625. $error++;
  626. setEventMessages($object->error, $object->errors, 'errors');
  627. }
  628. }
  629. if (! $error)
  630. {
  631. $db->commit();
  632. setEventMessages($langs->trans("SiteDeleted", $object->ref, $websitekey), null, 'mesgs');
  633. header("Location: ".$_SERVER["PHP_SELF"]);
  634. exit;
  635. }
  636. else
  637. {
  638. $db->rollback();
  639. dol_print_error($db);
  640. }
  641. }
  642. // Delete page
  643. if ($action == 'delete')
  644. {
  645. $error = 0;
  646. $db->begin();
  647. $res = $object->fetch(0, $websitekey);
  648. $website = $object;
  649. $res = $objectpage->fetch($pageid, $object->fk_website);
  650. if ($res > 0)
  651. {
  652. $res = $objectpage->delete($user);
  653. if ($res <= 0)
  654. {
  655. $error++;
  656. setEventMessages($objectpage->error, $objectpage->errors, 'errors');
  657. }
  658. }
  659. if (! $error)
  660. {
  661. $db->commit();
  662. setEventMessages($langs->trans("PageDeleted", $objectpage->pageurl, $websitekey), null, 'mesgs');
  663. header("Location: ".$_SERVER["PHP_SELF"].'?website='.$websitekey);
  664. exit;
  665. }
  666. else
  667. {
  668. $db->rollback();
  669. dol_print_error($db);
  670. }
  671. }
  672. // Update css
  673. if ($action == 'updatecss')
  674. {
  675. if (GETPOST('refreshsite','alpha') || GETPOST('refreshpage','alpha')) // If we tried to reload another site/page, we stay on editcss mode.
  676. {
  677. $action='editcss';
  678. }
  679. else
  680. {
  681. $res = $object->fetch(0, $websitekey);
  682. $website = $object;
  683. // Html header file
  684. $htmlheadercontent ='';
  685. /* We disable php code since htmlheader is never executed as an include but only read by fgets_content.
  686. $htmlheadercontent.= "<?php // BEGIN PHP\n";
  687. $htmlheadercontent.= '$websitekey=basename(dirname(__FILE__));'."\n";
  688. $htmlheadercontent.= "if (! defined('USEDOLIBARRSERVER')) { require_once './master.inc.php'; } // Not already loaded"."\n";
  689. $htmlheadercontent.= "require_once DOL_DOCUMENT_ROOT.'/core/lib/website.lib.php';\n";
  690. $htmlheadercontent.= "require_once DOL_DOCUMENT_ROOT.'/core/website.inc.php';\n";
  691. $htmlheadercontent.= "ob_start();\n";
  692. // $htmlheadercontent.= "header('Content-type: text/html');\n"; // Not required. htmlheader.html is never call as a standalone page
  693. $htmlheadercontent.= "// END PHP ?>\n";*/
  694. $htmlheadercontent.= preg_replace(array('/<html>\n*/ims','/<\/html>\n*/ims'),array('',''),GETPOST('WEBSITE_HTML_HEADER', 'none'));
  695. /*$htmlheadercontent.= "\n".'<?php // BEGIN PHP'."\n";
  696. $htmlheadercontent.= '$tmp = ob_get_contents(); ob_end_clean(); dolWebsiteOutput($tmp);'."\n";
  697. $htmlheadercontent.= "// END PHP ?>"."\n";*/
  698. $htmlheadercontent = trim($htmlheadercontent)."\n";
  699. dolSaveHtmlHeader($filehtmlheader, $htmlheadercontent);
  700. // Css file
  701. $csscontent ='';
  702. $csscontent.= "<?php // BEGIN PHP\n";
  703. $csscontent.= '$websitekey=basename(dirname(__FILE__));'."\n";
  704. $csscontent.= "if (! defined('USEDOLIBARRSERVER')) { require_once dirname(__FILE__).'/master.inc.php'; } // Not already loaded"."\n"; // For the css, we need to set path of master using the dirname of css file.
  705. $csscontent.= "require_once DOL_DOCUMENT_ROOT.'/core/lib/website.lib.php';\n";
  706. $csscontent.= "require_once DOL_DOCUMENT_ROOT.'/core/website.inc.php';\n";
  707. $csscontent.= "ob_start();\n";
  708. $csscontent.= "header('Content-type: text/css');\n";
  709. $csscontent.= "// END PHP ?>\n";
  710. $csscontent.= GETPOST('WEBSITE_CSS_INLINE', 'none');
  711. $csscontent.= "\n".'<?php // BEGIN PHP'."\n";
  712. $csscontent.= '$tmp = ob_get_contents(); ob_end_clean(); dolWebsiteOutput($tmp);'."\n";
  713. $csscontent.= "// END PHP ?>"."\n";
  714. dol_syslog("Save css content into ".$filecss);
  715. dol_mkdir($pathofwebsite);
  716. $result = file_put_contents($filecss, $csscontent);
  717. if (! empty($conf->global->MAIN_UMASK))
  718. @chmod($filecss, octdec($conf->global->MAIN_UMASK));
  719. if (! $result)
  720. {
  721. $error++;
  722. setEventMessages('Failed to write file '.$filecss, null, 'errors');
  723. }
  724. // Js file
  725. $jscontent ='';
  726. $jscontent.= "<?php // BEGIN PHP\n";
  727. $jscontent.= '$websitekey=basename(dirname(__FILE__));'."\n";
  728. $jscontent.= "if (! defined('USEDOLIBARRSERVER')) { require_once dirname(__FILE__).'/master.inc.php'; } // Not already loaded"."\n"; // For the css, we need to set path of master using the dirname of css file.
  729. $jscontent.= "require_once DOL_DOCUMENT_ROOT.'/core/lib/website.lib.php';\n";
  730. $jscontent.= "require_once DOL_DOCUMENT_ROOT.'/core/website.inc.php';\n";
  731. $jscontent.= "ob_start();\n";
  732. $jscontent.= "header('Content-type: application/javascript');\n";
  733. $jscontent.= "// END PHP ?>\n";
  734. $jscontent.= GETPOST('WEBSITE_JS_INLINE', 'none');
  735. $jscontent.= "\n".'<?php // BEGIN PHP'."\n";
  736. $jscontent.= '$tmp = ob_get_contents(); ob_end_clean(); dolWebsiteOutput($tmp);'."\n";
  737. $jscontent.= "// END PHP ?>"."\n";
  738. dol_syslog("Save js content into ".$filejs);
  739. dol_mkdir($pathofwebsite);
  740. $result = file_put_contents($filejs, $jscontent);
  741. if (! empty($conf->global->MAIN_UMASK))
  742. @chmod($filejs, octdec($conf->global->MAIN_UMASK));
  743. if (! $result)
  744. {
  745. $error++;
  746. setEventMessages('Failed to write file '.$filejs, null, 'errors');
  747. }
  748. // Robot file
  749. $robotcontent ='';
  750. /*$robotcontent.= "<?php // BEGIN PHP\n";
  751. $robotcontent.= '$websitekey=basename(dirname(__FILE__));'."\n";
  752. $robotcontent.= "if (! defined('USEDOLIBARRSERVER')) { require_once './master.inc.php'; } // Not already loaded"."\n";
  753. $robotcontent.= "require_once DOL_DOCUMENT_ROOT.'/core/lib/website.lib.php';\n";
  754. $robotcontent.= "require_once DOL_DOCUMENT_ROOT.'/core/website.inc.php';\n";
  755. $robotcontent.= "ob_start();\n";
  756. $robotcontent.= "header('Content-type: text/css');\n";
  757. $robotcontent.= "// END PHP ?>\n";*/
  758. $robotcontent.= GETPOST('WEBSITE_ROBOT', 'none');
  759. /*$robotcontent.= "\n".'<?php // BEGIN PHP'."\n";
  760. $robotcontent.= '$tmp = ob_get_contents(); ob_end_clean(); dolWebsiteOutput($tmp);'."\n";
  761. $robotcontent.= "// END PHP ?>"."\n";*/
  762. dol_syslog("Save file robot into ".$filerobot);
  763. dol_mkdir($pathofwebsite);
  764. $result = file_put_contents($filerobot, $robotcontent);
  765. if (! empty($conf->global->MAIN_UMASK))
  766. @chmod($filerobot, octdec($conf->global->MAIN_UMASK));
  767. if (! $result)
  768. {
  769. $error++;
  770. setEventMessages('Failed to write file '.$filerobot, null, 'errors');
  771. }
  772. // Css file
  773. $htaccesscontent ='';
  774. /*$robotcontent.= "<?php // BEGIN PHP\n";
  775. $robotcontent.= '$websitekey=basename(dirname(__FILE__));'."\n";
  776. $robotcontent.= "if (! defined('USEDOLIBARRSERVER')) { require_once './master.inc.php'; } // Not already loaded"."\n";
  777. $robotcontent.= "require_once DOL_DOCUMENT_ROOT.'/core/lib/website.lib.php';\n";
  778. $robotcontent.= "require_once DOL_DOCUMENT_ROOT.'/core/website.inc.php';\n";
  779. $robotcontent.= "ob_start();\n";
  780. $robotcontent.= "header('Content-type: text/css');\n";
  781. $robotcontent.= "// END PHP ?>\n";*/
  782. $htaccesscontent.= GETPOST('WEBSITE_HTACCESS', 'none');
  783. /*$robotcontent.= "\n".'<?php // BEGIN PHP'."\n";
  784. $robotcontent.= '$tmp = ob_get_contents(); ob_end_clean(); dolWebsiteOutput($tmp);'."\n";
  785. $robotcontent.= "// END PHP ?>"."\n";*/
  786. dol_syslog("Save file htaccess into ".$filehtaccess);
  787. dol_mkdir($pathofwebsite);
  788. $result = file_put_contents($filehtaccess, $htaccesscontent);
  789. if (! empty($conf->global->MAIN_UMASK))
  790. @chmod($filehtaccess, octdec($conf->global->MAIN_UMASK));
  791. if (! $result)
  792. {
  793. $error++;
  794. setEventMessages('Failed to write file '.$filehtaccess, null, 'errors');
  795. }
  796. // Message if no error
  797. if (! $error)
  798. {
  799. setEventMessages($langs->trans("Saved"), null, 'mesgs');
  800. }
  801. $action='preview';
  802. }
  803. }
  804. // Update page
  805. if ($action == 'setashome')
  806. {
  807. $db->begin();
  808. $object->fetch(0, $websitekey);
  809. $website = $object;
  810. $object->fk_default_home = $pageid;
  811. $res = $object->update($user);
  812. if (! $res > 0)
  813. {
  814. $error++;
  815. setEventMessages($object->error, $object->errors, 'errors');
  816. }
  817. if (! $error)
  818. {
  819. $db->commit();
  820. // Generate the index.php page to be the home page
  821. //-------------------------------------------------
  822. $result = dolSaveIndexPage($pathofwebsite, $fileindex, $filetpl);
  823. if ($result) setEventMessages($langs->trans("Saved"), null, 'mesgs');
  824. else setEventMessages('Failed to write file '.$fileindex, null, 'errors');
  825. $action='preview';
  826. }
  827. else
  828. {
  829. $db->rollback();
  830. }
  831. }
  832. // Update page (meta)
  833. if ($action == 'updatemeta')
  834. {
  835. $db->begin();
  836. $result = $object->fetch(0, $websitekey);
  837. $website = $object;
  838. $objectpage->fk_website = $object->id;
  839. // Check parameters
  840. if (! preg_match('/^[a-z0-9\-\_]+$/i', GETPOST('WEBSITE_PAGENAME', 'alpha')))
  841. {
  842. $error++;
  843. $langs->load("errors");
  844. setEventMessages($langs->transnoentities("ErrorFieldCanNotContainSpecialCharacters", $langs->transnoentities('WEBSITE_PAGENAME')), null, 'errors');
  845. $action='editmeta';
  846. }
  847. $res = $objectpage->fetch($pageid, $object->id);
  848. if ($res <= 0)
  849. {
  850. $error++;
  851. setEventMessages('Page not found '.$objectpage->error, $objectpage->errors, 'errors');
  852. }
  853. // Check alias not exists
  854. if (! $error && GETPOST('WEBSITE_PAGENAME', 'alpha'))
  855. {
  856. $websitepagetemp=new WebsitePage($db);
  857. $result = $websitepagetemp->fetch(-1 * $objectpage->id, $object->id, GETPOST('WEBSITE_PAGENAME', 'alpha'));
  858. if ($result < 0)
  859. {
  860. $error++;
  861. $langs->load("errors");
  862. setEventMessages($websitepagetemp->error, $websitepagetemp->errors, 'errors');
  863. $action = 'editmeta';
  864. }
  865. if ($result > 0)
  866. {
  867. $error++;
  868. $langs->load("errors");
  869. setEventMessages($langs->trans("ErrorAPageWithThisNameOrAliasAlreadyExists", $websitepagetemp->pageurl), null, 'errors');
  870. $action = 'editmeta';
  871. }
  872. }
  873. if (! $error && GETPOST('WEBSITE_ALIASALT', 'alpha'))
  874. {
  875. $arrayofaliastotest=explode(',', GETPOST('WEBSITE_ALIASALT', 'alpha'));
  876. $websitepagetemp=new WebsitePage($db);
  877. foreach($arrayofaliastotest as $aliastotest)
  878. {
  879. $result = $websitepagetemp->fetch(-1 * $objectpage->id, $object->id, $aliastotest);
  880. if ($result < 0)
  881. {
  882. $error++;
  883. $langs->load("errors");
  884. setEventMessages($websitepagetemp->error, $websitepagetemp->errors, 'errors');
  885. $action = 'editmeta';
  886. break;
  887. }
  888. if ($result > 0)
  889. {
  890. $error++;
  891. $langs->load("errors");
  892. setEventMessages($langs->trans("ErrorAPageWithThisNameOrAliasAlreadyExists", $websitepagetemp->pageurl), null, 'errors');
  893. $action = 'editmeta';
  894. break;
  895. }
  896. }
  897. }
  898. if (! $error)
  899. {
  900. $objectpage->old_object = clone $objectpage;
  901. $objectpage->title = GETPOST('WEBSITE_TITLE', 'alpha');
  902. $objectpage->type_container = GETPOST('WEBSITE_TYPE_CONTAINER', 'alpha');
  903. $objectpage->pageurl = GETPOST('WEBSITE_PAGENAME', 'alpha');
  904. $objectpage->aliasalt = GETPOST('WEBSITE_ALIASALT', 'alpha');
  905. $objectpage->description = GETPOST('WEBSITE_DESCRIPTION', 'alpha');
  906. $objectpage->keywords = GETPOST('WEBSITE_KEYWORDS', 'alpha');
  907. $objectpage->lang = GETPOST('WEBSITE_LANG', 'aZ09');
  908. $objectpage->htmlheader = trim(GETPOST('htmlheader', 'none'));
  909. $res = $objectpage->update($user);
  910. if (! ($res > 0))
  911. {
  912. $langs->load("errors");
  913. if ($db->lasterrno == 'DB_ERROR_RECORD_ALREADY_EXISTS')
  914. {
  915. $error++;
  916. $langs->load("errors");
  917. setEventMessages($langs->trans("ErrorAPageWithThisNameOrAliasAlreadyExists"), null, 'errors');
  918. $action = 'editmeta';
  919. }
  920. else
  921. {
  922. $error++;
  923. $langs->load("errors");
  924. setEventMessages($objectpage->error, $objectpage->errors, 'errors');
  925. $action = 'editmeta';
  926. }
  927. }
  928. }
  929. if (! $error)
  930. {
  931. $db->commit();
  932. }
  933. else
  934. {
  935. $db->rollback();
  936. }
  937. if (! $error)
  938. {
  939. $filemaster=$pathofwebsite.'/master.inc.php';
  940. $fileoldalias=$pathofwebsite.'/'.$objectpage->old_object->pageurl.'.php';
  941. $filealias=$pathofwebsite.'/'.$objectpage->pageurl.'.php';
  942. dol_mkdir($pathofwebsite);
  943. // Now generate the master.inc.php page
  944. dol_syslog("We regenerate the master file (because we update meta)");
  945. dol_delete_file($filemaster);
  946. $mastercontent = '<?php'."\n";
  947. $mastercontent.= '// File generated to link to the master file - DO NOT MODIFY - It is just an include'."\n";
  948. $mastercontent.= "if (! defined('USEDOLIBARRSERVER')) require_once '".DOL_DOCUMENT_ROOT."/master.inc.php';\n";
  949. //$mastercontent.= "include_once DOL_DOCUMENT_ROOT.'/website/class/website.class.php';"."\n";
  950. //$mastercontent.= '$website = new WebSite($db)'."\n";
  951. $mastercontent.= '?>'."\n";
  952. $result = file_put_contents($filemaster, $mastercontent);
  953. if (! empty($conf->global->MAIN_UMASK))
  954. @chmod($filemaster, octdec($conf->global->MAIN_UMASK));
  955. if (! $result) setEventMessages('Failed to write file '.$filemaster, null, 'errors');
  956. // Now delete the alias.php page
  957. if (! empty($fileoldalias))
  958. {
  959. dol_syslog("We delete old alias page name=".$fileoldalias." to build a new alias page=".$filealias);
  960. dol_delete_file($fileoldalias);
  961. }
  962. // Now delete the alternative alias.php pages
  963. if (! empty($objectpage->old_object->aliasalt))
  964. {
  965. $tmpaltaliases=explode(',', $objectpage->old_object->aliasalt);
  966. if (is_array($tmpaltaliases))
  967. {
  968. foreach($tmpaltaliases as $tmpaliasalt)
  969. {
  970. dol_syslog("We delete old alt alias pages name=".trim($tmpaliasalt));
  971. dol_delete_file($pathofwebsite.'/'.trim($tmpaliasalt).'.php');
  972. }
  973. }
  974. }
  975. // Save page alias
  976. $result=dolSavePageAlias($filealias, $object, $objectpage);
  977. if (! $result) setEventMessages('Failed to write file '.$filealias, null, 'errors');
  978. // Save alt aliases
  979. if (! empty($objectpage->aliasalt))
  980. {
  981. $tmpaltaliases=explode(',', $objectpage->aliasalt);
  982. if (is_array($tmpaltaliases))
  983. {
  984. foreach($tmpaltaliases as $tmpaliasalt)
  985. {
  986. $result=dolSavePageAlias($pathofwebsite.'/'.trim($tmpaliasalt).'.php', $object, $objectpage);
  987. if (! $result) setEventMessages('Failed to write file '.$pathofwebsite.'/'.trim($tmpaliasalt).'.php', null, 'errors');
  988. }
  989. }
  990. }
  991. // Save page of content
  992. $result=dolSavePageContent($filetpl, $object, $objectpage);
  993. if ($result)
  994. {
  995. setEventMessages($langs->trans("Saved"), null, 'mesgs');
  996. //header("Location: ".$_SERVER["PHP_SELF"].'?website='.$websitekey.'&pageid='.$pageid);
  997. //exit;
  998. }
  999. else
  1000. {
  1001. setEventMessages('Failed to write file '.$filetpl, null, 'errors');
  1002. //header("Location: ".$_SERVER["PHP_SELF"].'?website='.$websitekey.'&pageid='.$pageid);
  1003. //exit;
  1004. }
  1005. $action='preview';
  1006. }
  1007. }
  1008. // Update page
  1009. if (($action == 'updatesource' || $action == 'updatecontent' || $action == 'confirm_createfromclone' || $action == 'confirm_createpagefromclone')
  1010. || ($action == 'preview' && (GETPOST('refreshsite') || GETPOST('refreshpage') || GETPOST('preview'))))
  1011. {
  1012. $object->fetch(0, $websitekey);
  1013. $website = $object;
  1014. if ($action == 'confirm_createfromclone')
  1015. {
  1016. $objectnew = new Website($db);
  1017. $result = $objectnew->createFromClone($user, GETPOST('id','int'), GETPOST('siteref','aZ09'), (GETPOST('newlang','aZ09')?GETPOST('newlang','aZ09'):''));
  1018. if ($result < 0)
  1019. {
  1020. $error++;
  1021. setEventMessages($objectnew->error, $objectnew->errors, 'errors');
  1022. $action='preview';
  1023. }
  1024. else
  1025. {
  1026. $object = $objectnew;
  1027. $id = $object->id;
  1028. $pageid = $object->fk_default_home;
  1029. $websitekey = GETPOST('siteref','aZ09');
  1030. }
  1031. }
  1032. if ($action == 'confirm_createpagefromclone')
  1033. {
  1034. $istranslation=(GETPOST('is_a_translation','aZ09')=='on'?1:0);
  1035. if ($istranslation)
  1036. {
  1037. if (GETPOST('newlang','aZ09') == $objectpage->lang)
  1038. {
  1039. $error++;
  1040. setEventMessages($langs->trans("LanguageMustNotBeSameThanClonedPage"), null, 'errors');
  1041. $action='preview';
  1042. }
  1043. }
  1044. if (! $error)
  1045. {
  1046. $objectpage = new WebsitePage($db);
  1047. $result = $objectpage->createFromClone($user, $pageid, GETPOST('pageurl','aZ09'), (GETPOST('newlang','aZ09')?GETPOST('newlang','aZ09'):''), $istranslation, GETPOST('newwebsite','int'));
  1048. if ($result < 0)
  1049. {
  1050. $error++;
  1051. setEventMessages($objectpage->error, $objectpage->errors, 'errors');
  1052. $action='createpagefromclone';
  1053. }
  1054. else
  1055. {
  1056. // TODO Switch on the new page ?
  1057. }
  1058. }
  1059. }
  1060. $res = 0;
  1061. if (! $error)
  1062. {
  1063. // Check symlink to medias and restore it if ko
  1064. $pathtomedias=DOL_DATA_ROOT.'/medias';
  1065. $pathtomediasinwebsite=$pathofwebsite.'/medias';
  1066. if (! is_link(dol_osencode($pathtomediasinwebsite)))
  1067. {
  1068. dol_syslog("Create symlink for ".$pathtomedias." into name ".$pathtomediasinwebsite);
  1069. dol_mkdir(dirname($pathtomediasinwebsite)); // To be sure dir for website exists
  1070. $result = symlink($pathtomedias, $pathtomediasinwebsite);
  1071. }
  1072. /*if (GETPOST('savevirtualhost') && $object->virtualhost != GETPOST('previewsite'))
  1073. {
  1074. $object->virtualhost = GETPOST('previewsite', 'alpha');
  1075. $object->update($user);
  1076. }*/
  1077. $objectpage->fk_website = $object->id;
  1078. if ($pageid > 0)
  1079. {
  1080. $res = $objectpage->fetch($pageid);
  1081. }
  1082. else
  1083. {
  1084. $res=0;
  1085. if ($object->fk_default_home > 0)
  1086. {
  1087. $res = $objectpage->fetch($object->fk_default_home);
  1088. }
  1089. if (! ($res > 0))
  1090. {
  1091. $res = $objectpage->fetch(0, $object->id);
  1092. }
  1093. }
  1094. }
  1095. if (! $error && $res > 0)
  1096. {
  1097. if ($action == 'updatesource' || $action == 'updatecontent')
  1098. {
  1099. $db->begin();
  1100. $objectpage->content = GETPOST('PAGE_CONTENT','none');
  1101. // Clean data. We remove all the head section.
  1102. $objectpage->content = preg_replace('/<head>.*<\/head>/s', '', $objectpage->content);
  1103. /* $objectpage->content = preg_replace('/<base\s+href=[\'"][^\'"]+[\'"]\s/?>/s', '', $objectpage->content); */
  1104. $res = $objectpage->update($user);
  1105. if ($res < 0)
  1106. {
  1107. $error++;
  1108. setEventMessages($objectpage->error, $objectpage->errors, 'errors');
  1109. }
  1110. if (! $error)
  1111. {
  1112. $db->commit();
  1113. $filemaster=$pathofwebsite.'/master.inc.php';
  1114. //$fileoldalias=$pathofwebsite.'/'.$objectpage->old_object->pageurl.'.php';
  1115. $filealias=$pathofwebsite.'/'.$objectpage->pageurl.'.php';
  1116. dol_mkdir($pathofwebsite);
  1117. // Now generate the master.inc.php page
  1118. dol_syslog("We regenerate the master file");
  1119. dol_delete_file($filemaster);
  1120. $mastercontent = '<?php'."\n";
  1121. $mastercontent.= '// File generated to link to the master file'."\n";
  1122. $mastercontent.= "if (! defined('USEDOLIBARRSERVER')) require_once '".DOL_DOCUMENT_ROOT."/master.inc.php';\n";
  1123. $mastercontent.= '?>'."\n";
  1124. $result = file_put_contents($filemaster, $mastercontent);
  1125. if (! empty($conf->global->MAIN_UMASK))
  1126. @chmod($filemaster, octdec($conf->global->MAIN_UMASK));
  1127. if (! $result) setEventMessages('Failed to write file '.$filemaster, null, 'errors');
  1128. // Now generate the alias.php page
  1129. if (! empty($fileoldalias))
  1130. {
  1131. dol_syslog("We regenerate alias page new name=".$filealias.", old name=".$fileoldalias);
  1132. dol_delete_file($fileoldalias);
  1133. }
  1134. // Save page alias
  1135. $result=dolSavePageAlias($filealias, $object, $objectpage);
  1136. if (! $result) setEventMessages('Failed to write file '.$filealias, null, 'errors');
  1137. // Save page content
  1138. $result=dolSavePageContent($filetpl, $object, $objectpage);
  1139. if ($result)
  1140. {
  1141. setEventMessages($langs->trans("Saved"), null, 'mesgs');
  1142. header("Location: ".$_SERVER["PHP_SELF"].'?website='.$websitekey.'&pageid='.$pageid);
  1143. exit;
  1144. }
  1145. else
  1146. {
  1147. setEventMessages('Failed to write file '.$filetpl, null, 'errors');
  1148. header("Location: ".$_SERVER["PHP_SELF"].'?website='.$websitekey.'&pageid='.$pageid);
  1149. exit;
  1150. }
  1151. }
  1152. else
  1153. {
  1154. $db->rollback();
  1155. }
  1156. }
  1157. else
  1158. {
  1159. header("Location: ".$_SERVER["PHP_SELF"].'?website='.$websitekey.'&pageid='.$pageid);
  1160. exit;
  1161. }
  1162. }
  1163. else
  1164. {
  1165. if (! $error)
  1166. {
  1167. setEventMessages($langs->trans("NoPageYet"), null, 'warnings');
  1168. setEventMessages($langs->trans("YouCanCreatePageOrImportTemplate"), null, 'warnings');
  1169. }
  1170. }
  1171. }
  1172. // Export site
  1173. if ($action == 'exportsite')
  1174. {
  1175. $fileofzip = $object->exportWebSite();
  1176. if ($fileofzip)
  1177. {
  1178. $file_name = basename($fileofzip);
  1179. header("Content-Type: application/zip");
  1180. header("Content-Disposition: attachment; filename=".$file_name);
  1181. header("Content-Length: " . filesize($fileofzip));
  1182. readfile($fileofzip);
  1183. exit;
  1184. }
  1185. }
  1186. // Import site
  1187. if ($action == 'importsiteconfirm')
  1188. {
  1189. if (empty($_FILES))
  1190. {
  1191. setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("File")), null, 'errors');
  1192. $action = 'importsite';
  1193. }
  1194. else
  1195. {
  1196. if (! empty($_FILES))
  1197. {
  1198. if (is_array($_FILES['userfile']['tmp_name'])) $userfiles=$_FILES['userfile']['tmp_name'];
  1199. else $userfiles=array($_FILES['userfile']['tmp_name']);
  1200. foreach($userfiles as $key => $userfile)
  1201. {
  1202. if (empty($_FILES['userfile']['tmp_name'][$key]))
  1203. {
  1204. $error++;
  1205. if ($_FILES['userfile']['error'][$key] == 1 || $_FILES['userfile']['error'][$key] == 2){
  1206. setEventMessages($langs->trans('ErrorFileSizeTooLarge'), null, 'errors');
  1207. $action = 'importsite';
  1208. }
  1209. else {
  1210. setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("File")), null, 'errors');
  1211. $action = 'importsite';
  1212. }
  1213. }
  1214. }
  1215. if (! $error)
  1216. {
  1217. $upload_dir = $conf->website->dir_temp;
  1218. $result = dol_add_file_process($upload_dir, 1, -1, 'userfile', '');
  1219. // Get name of file (take last one if several name provided)
  1220. $fileofzip = $upload_dir.'/unknown';
  1221. foreach($_FILES as $key => $ifile)
  1222. {
  1223. foreach($ifile['name'] as $key2 => $ifile2)
  1224. {
  1225. $fileofzip = $upload_dir . '/' .$ifile2;
  1226. }
  1227. }
  1228. $result = $object->importWebSite($fileofzip);
  1229. if ($result < 0)
  1230. {
  1231. setEventMessages($object->error, $object->errors, 'errors');
  1232. $action = 'importsite';
  1233. }
  1234. else
  1235. {
  1236. header("Location: ".$_SERVER["PHP_SELF"].'?website='.$object->ref);
  1237. exit();
  1238. }
  1239. }
  1240. }
  1241. }
  1242. }
  1243. /*
  1244. * View
  1245. */
  1246. $form = new Form($db);
  1247. $formadmin = new FormAdmin($db);
  1248. $formwebsite = new FormWebsite($db);
  1249. $formother = new FormOther($db);
  1250. $help_url='';
  1251. $arrayofjs = array(
  1252. '/includes/ace/ace.js',
  1253. '/includes/ace/ext-statusbar.js',
  1254. '/includes/ace/ext-language_tools.js',
  1255. //'/includes/ace/ext-chromevox.js'
  1256. //'/includes/jquery/plugins/jqueryscoped/jquery.scoped.js',
  1257. );
  1258. $arrayofcss = array();
  1259. $moreheadcss='';
  1260. $moreheadjs='';
  1261. $arrayofjs[]='includes/jquery/plugins/blockUI/jquery.blockUI.js';
  1262. $arrayofjs[]='core/js/blockUI.js'; // Used by ecm/tpl/enabledfiletreeajax.tpl.php
  1263. if (empty($conf->global->MAIN_ECM_DISABLE_JS)) $arrayofjs[]="includes/jquery/plugins/jqueryFileTree/jqueryFileTree.js";
  1264. $moreheadjs.='<script type="text/javascript">'."\n";
  1265. $moreheadjs.='var indicatorBlockUI = \''.DOL_URL_ROOT."/theme/".$conf->theme."/img/working.gif".'\';'."\n";
  1266. $moreheadjs.='</script>'."\n";
  1267. llxHeader($moreheadcss.$moreheadjs, $langs->trans("websiteetup"), $help_url, '', 0, 0, $arrayofjs, $arrayofcss, '', '', '<!-- Begin div class="fiche" -->'."\n".'<div class="fichebutwithotherclass">');
  1268. print "\n".'<form action="'.$_SERVER["PHP_SELF"].'" method="POST" enctype="multipart/form-data">';
  1269. print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">';
  1270. if ($action == 'createsite')
  1271. {
  1272. print '<input type="hidden" name="action" value="addsite">';
  1273. }
  1274. if ($action == 'createcontainer')
  1275. {
  1276. print '<input type="hidden" name="action" value="addcontainer">';
  1277. }
  1278. if ($action == 'editcss')
  1279. {
  1280. print '<input type="hidden" name="action" value="updatecss">';
  1281. }
  1282. if ($action == 'editmenu')
  1283. {
  1284. print '<input type="hidden" name="action" value="updatemenu">';
  1285. }
  1286. if ($action == 'setashome')
  1287. {
  1288. print '<input type="hidden" name="action" value="updateashome">';
  1289. }
  1290. if ($action == 'editmeta')
  1291. {
  1292. print '<input type="hidden" name="action" value="updatemeta">';
  1293. }
  1294. if ($action == 'editsource')
  1295. {
  1296. print '<input type="hidden" name="action" value="updatesource">';
  1297. }
  1298. if ($action == 'editcontent')
  1299. {
  1300. print '<input type="hidden" name="action" value="updatecontent">';
  1301. }
  1302. if ($action == 'edit')
  1303. {
  1304. print '<input type="hidden" name="action" value="update">';
  1305. }
  1306. if ($action == 'importsite')
  1307. {
  1308. print '<input type="hidden" name="action" value="importsiteconfirm">';
  1309. }
  1310. if ($action == 'file_manager')
  1311. {
  1312. print '<input type="hidden" name="action" value="file_manager">';
  1313. }
  1314. print '<div>';
  1315. // Add a margin under toolbar ?
  1316. $style='';
  1317. if ($action != 'preview' && $action != 'editcontent' && $action != 'editsource') $style=' margin-bottom: 5px;';
  1318. if (! GETPOST('hide_websitemenu'))
  1319. {
  1320. //var_dump($objectpage);exit;
  1321. print '<div class="centpercent websitebar">';
  1322. if (count($object->records) > 0)
  1323. {
  1324. // ***** Part for web sites
  1325. print '<div class="websiteselection hideonsmartphoneimp minwidth100 tdoverflowmax100">';
  1326. print $langs->trans("Website").' : ';
  1327. print '</div>';
  1328. print '<div class="websiteselection hideonsmartphoneimp">';
  1329. print ' <input type="submit"'.$disabled.' class="button" value="'.dol_escape_htmltag($langs->trans("Add")).'" name="createsite">';
  1330. print '</div>';
  1331. // List of website
  1332. print '<div class="websiteselection">';
  1333. $out='';
  1334. $out.='<select name="website" class="minwidth100" id="website">';
  1335. if (empty($object->records)) $out.='<option value="-1">&nbsp;</option>';
  1336. // Loop on each sites
  1337. $i=0;
  1338. foreach($object->records as $key => $valwebsite)
  1339. {
  1340. if (empty($websitekey)) $websitekey=$valwebsite->ref;
  1341. $out.='<option value="'.$valwebsite->ref.'"';
  1342. if ($websitekey == $valwebsite->ref) $out.=' selected'; // To preselect a value
  1343. $out.='>';
  1344. $out.=$valwebsite->ref;
  1345. $out.='</option>';
  1346. $i++;
  1347. }
  1348. $out.='</select>';
  1349. $out.=ajax_combobox('website');
  1350. print $out;
  1351. //print '<input type="submit" class="button" name="refreshsite" value="'.$langs->trans("Load").'">';
  1352. print '<input type="image" class="valignmiddle" src="'.img_picto('', 'refresh', '', 0, 1).'" name="refreshpage" value="'.$langs->trans("Load").'">';
  1353. if ($websitekey)
  1354. {
  1355. $virtualurl='';
  1356. $dataroot=DOL_DATA_ROOT.'/website/'.$websitekey;
  1357. if (! empty($object->virtualhost)) $virtualurl=$object->virtualhost;
  1358. }
  1359. $array=$objectpage->fetchAll($object->id, 'ASC,ASC', 'type_container,pageurl');
  1360. if (! is_array($array) && $array < 0) dol_print_error('', $objectpage->error, $objectpage->errors);
  1361. $atleastonepage=(is_array($array) && count($array) > 0);
  1362. if ($websitekey && ($action == 'preview' || $action == 'createfromclone' || $action == 'createpagefromclone'))
  1363. {
  1364. $disabled='';
  1365. if (empty($user->rights->website->write)) $disabled=' disabled="disabled"';
  1366. print ' &nbsp; ';
  1367. print '<input type="submit" class="button nobordertransp"'.$disabled.' value="'.dol_escape_htmltag($langs->trans("EditCss")).'" name="editcss">';
  1368. //print '<input type="submit" class="button"'.$disabled.' value="'.dol_escape_htmltag($langs->trans("EditMenu")).'" name="editmenu">';
  1369. print '<input type="submit" class="button nobordertransp"'.$disabled.' value="'.dol_escape_htmltag($langs->trans("CloneSite")).'" name="createfromclone">';
  1370. print '<input type="submit" class="button nobordertransp"'.$disabled.' value="'.dol_escape_htmltag($langs->trans("ExportSite")).'" name="exportsite">';
  1371. if (! $atleastonepage)
  1372. {
  1373. print '<input type="submit" class="button nobordertransp"'.$disabled.' value="'.dol_escape_htmltag($langs->trans("ImportSite")).'" name="importsite">';
  1374. }
  1375. else
  1376. {
  1377. print '<input type="submit" class="button nobordertransp" disabled="disabled" value="'.dol_escape_htmltag($langs->trans("ImportSite")).'" name="importsite">';
  1378. }
  1379. print '<input type="submit" class="buttonDelete" name="deletesite" value="'.$langs->trans("Delete").'"'.($atleastonepage?' disabled="disabled"':'').'>';
  1380. print ' &nbsp; ';
  1381. print '<input type="submit" class="button nobordertransp"'.$disabled.' value="'.dol_escape_htmltag($langs->trans("MediaFiles")).'" name="file_manager">';
  1382. /*print '<a class="button button_file_manager"'.$disabled.'>'.dol_escape_htmltag($langs->trans("MediaFiles")).'</a>';
  1383. print '<script language="javascript">
  1384. jQuery(document).ready(function () {
  1385. jQuery(".button_file_manager").click(function () {
  1386. var $dialog = $(\'<div></div>\').html(\'<iframe style="border: 0px;" src="'.DOL_URL_ROOT.'/website/index.php?hide_websitemenu=1&dol_hide_topmenu=1&dol_hide_leftmenu=1&file_manager=1&website='.$websitekey.'&pageid='.$pageid.'" width="100%" height="100%"></iframe>\')
  1387. .dialog({
  1388. autoOpen: false,
  1389. modal: true,
  1390. height: 500,
  1391. width: \'80%\',
  1392. title: "'.dol_escape_js($langs->trans("FileManager")).'"
  1393. });
  1394. $dialog.dialog(\'open\');
  1395. });
  1396. });
  1397. </script>';
  1398. */
  1399. }
  1400. print '</div>';
  1401. // Toolbar for website
  1402. print '<div class="websitetools">';
  1403. if ($action == 'preview' || $action == 'createfromclone' || $action == 'createpagefromclone')
  1404. {
  1405. $urlext=$virtualurl;
  1406. $urlint=$urlwithroot.'/public/website/index.php?website='.$websitekey;
  1407. $htmltext = $langs->trans("PreviewSiteServedByDolibarr", $langs->transnoentitiesnoconv("Site"), $langs->transnoentitiesnoconv("Site"), $urlint, $dataroot);
  1408. $htmltext.='<br>'.$langs->trans("CheckVirtualHostPerms", $langs->transnoentitiesnoconv("ReadPerm"), DOL_DOCUMENT_ROOT);
  1409. $htmltext.='<br>'.$langs->trans("CheckVirtualHostPerms", $langs->transnoentitiesnoconv("WritePerm"), DOL_DATA_ROOT);
  1410. print '<a class="websitebuttonsitepreview" id="previewsite" href="'.$urlwithroot.'/public/website/index.php?website='.$websitekey.'" target="tab'.$websitekey.'" alt="'.dol_escape_htmltag($htmltext).'">';
  1411. print $form->textwithpicto('', $htmltext, 1, 'preview');
  1412. print '</a>';
  1413. print '<div class="websiteinputurl" id="websiteinputurl">';
  1414. print '<input type="text" id="previewsiteurl" class="minwidth200imp" name="previewsite" placeholder="'.$langs->trans("http://myvirtualhost").'" value="'.$virtualurl.'">';
  1415. //print '<input type="submit" class="button" name="previewwebsite" target="tab'.$websitekey.'" value="'.$langs->trans("ViewSiteInNewTab").'">';
  1416. $htmltext =$langs->trans("SetHereVirtualHost", $dataroot);
  1417. $htmltext.='<br>';
  1418. $htmltext.='<br>'.$langs->trans("CheckVirtualHostPerms", $langs->transnoentitiesnoconv("ReadPerm"), DOL_DOCUMENT_ROOT);
  1419. $htmltext.='<br>'.$langs->trans("CheckVirtualHostPerms", $langs->transnoentitiesnoconv("WritePerm"), DOL_DATA_ROOT);
  1420. $htmltext.='<br>';
  1421. $htmltext.='<br>';
  1422. $htmltext.=$langs->trans("YouCanAlsoTestWithPHPS", $dataroot);
  1423. print $form->textwithpicto('', $htmltext, 1, 'help', '', 0, 2, 'helpvirtualhost');
  1424. print '</div>';
  1425. if (empty($object->fk_default_home))
  1426. {
  1427. $htmltext = '<span class="error">'.$langs->trans("YouMustDefineTheHomePage").'</span><br>'.$langs->trans("PreviewSiteServedByWebServer", $langs->transnoentitiesnoconv("Site"), $langs->transnoentitiesnoconv("Site"), $dataroot, $urlext?$urlext:'<span class="error">'.$langs->trans("VirtualHostUrlNotDefined").'</span>');
  1428. $htmltext.='<br>';
  1429. $htmltext.='<br>'.$langs->trans("CheckVirtualHostPerms", $langs->transnoentitiesnoconv("ReadPerm"), DOL_DOCUMENT_ROOT);
  1430. $htmltext.='<br>'.$langs->trans("CheckVirtualHostPerms", $langs->transnoentitiesnoconv("WritePerm"), DOL_DATA_ROOT);
  1431. print '<span class="websitebuttonsitepreview websitebuttonsitepreviewdisabled cursornotallowed" id="previewsiteextdisabled" href="" target="tab'.$websitekey.'ext" alt="'.dol_escape_htmltag($langs->trans("PreviewSiteServedByWebServer", $langs->transnoentitiesnoconv("Site"), $langs->transnoentitiesnoconv("Site"), $dataroot, $urlext)).'">';
  1432. print $form->textwithpicto('', $htmltext, 1, 'preview_ext');
  1433. print '</span>';
  1434. }
  1435. else
  1436. {
  1437. $htmltext = $langs->trans("PreviewSiteServedByWebServer", $langs->transnoentitiesnoconv("Site"), $langs->transnoentitiesnoconv("Site"), $dataroot, $urlext?$urlext:'<span class="error">'.$langs->trans("VirtualHostUrlNotDefined").'</span>');
  1438. $htmltext.='<br>';
  1439. $htmltext.='<br>'.$langs->trans("CheckVirtualHostPerms", $langs->transnoentitiesnoconv("ReadPerm"), DOL_DOCUMENT_ROOT);
  1440. $htmltext.='<br>'.$langs->trans("CheckVirtualHostPerms", $langs->transnoentitiesnoconv("WritePerm"), DOL_DATA_ROOT);
  1441. print '<a class="websitebuttonsitepreview'.($urlext?'':' websitebuttonsitepreviewdisabled cursornotallowed').'" id="previewsiteext" href="'.$urlext.'" target="tab'.$websitekey.'ext" alt="'.dol_escape_htmltag($langs->trans("PreviewSiteServedByWebServer", $langs->transnoentitiesnoconv("Site"), $langs->transnoentitiesnoconv("Site"), $dataroot, $urlext)).'">';
  1442. print $form->textwithpicto('', $htmltext, 1, 'preview_ext');
  1443. print '</a>';
  1444. }
  1445. }
  1446. if (in_array($action, array('editcss','editmenu','file_manager')))
  1447. {
  1448. if (preg_match('/^create/',$action) && $action != 'file_manager') print '<input type="submit" id="savefile" class="button buttonforacesave" value="'.dol_escape_htmltag($langs->trans("Save")).'" name="update">';
  1449. if (preg_match('/^edit/',$action) && $action != 'file_manager') print '<input type="submit" id="savefile" class="button buttonforacesave" value="'.dol_escape_htmltag($langs->trans("Save")).'" name="update">';
  1450. if ($action != 'preview') print '<input type="submit" class="button" value="'.dol_escape_htmltag($langs->trans("Cancel")).'" name="preview">';
  1451. }
  1452. print '</div>';
  1453. // Toolbar for pages
  1454. if ($websitekey && ! in_array($action, array('editcss','editmenu','importsite')))
  1455. {
  1456. print '</div>'; // Close current websitebar to open a new one
  1457. print '<div class="centpercent websitebar"'.($style?' style="'.$style.'"':'').'">';
  1458. print '<div class="websiteselection hideonsmartphoneimp minwidth100 tdoverflowmax100">';
  1459. print $langs->trans("PageContainer").': ';
  1460. print '</div>';
  1461. print '<div class="websiteselection hideonsmartphoneimp">';
  1462. print '<input type="submit"'.$disabled.' class="button" value="'.dol_escape_htmltag($langs->trans("Add")).'" name="createcontainer">';
  1463. print '</div>';
  1464. print '<div class="websiteselection">';
  1465. if ($action != 'addcontainer')
  1466. {
  1467. $out='';
  1468. $out.='<select name="pageid" id="pageid" class="minwidth200 maxwidth300">';
  1469. if ($atleastonepage)
  1470. {
  1471. if (empty($pageid) && $action != 'createcontainer') // Page id is not defined, we try to take one
  1472. {
  1473. $firstpageid=0;$homepageid=0;
  1474. foreach($array as $key => $valpage)
  1475. {
  1476. if (empty($firstpageid)) $firstpageid=$valpage->id;
  1477. if ($object->fk_default_home && $key == $object->fk_default_home) $homepageid=$valpage->id;
  1478. }
  1479. $pageid=$homepageid?$homepageid:$firstpageid; // We choose home page and if not defined yet, we take first page
  1480. }
  1481. foreach($array as $key => $valpage)
  1482. {
  1483. $out.='<option value="'.$key.'"';
  1484. if ($pageid > 0 && $pageid == $key) $out.=' selected'; // To preselect a value
  1485. $out.='>';
  1486. $out.='['.$valpage->type_container.' '.$valpage->id.'] ';
  1487. $out.=$valpage->pageurl.' - '.$valpage->title;
  1488. if ($object->fk_default_home && $key == $object->fk_default_home) $out.=' ('.$langs->trans("HomePage").')';
  1489. $out.='</option>';
  1490. }
  1491. }
  1492. else $out.='<option value="-1">&nbsp;</option>';
  1493. $out.='</select>';
  1494. $out.=ajax_combobox('pageid');
  1495. print $out;
  1496. }
  1497. else
  1498. {
  1499. print $langs->trans("New");
  1500. }
  1501. //print '<input type="submit" class="button" name="refreshpage" value="'.$langs->trans("Load").'"'.($atleastonepage?'':' disabled="disabled"').'>';
  1502. print '<input type="image" class="valignmiddle" src="'.img_picto('', 'refresh', '', 0, 1).'" name="refreshpage" value="'.$langs->trans("Load").'"'.($atleastonepage?'':' disabled="disabled"').'>';
  1503. // Print nav arrows
  1504. $pagepreviousid=0;
  1505. $pagenextid=0;
  1506. if ($pageid)
  1507. {
  1508. $sql = 'SELECT MAX(rowid) as pagepreviousid FROM '.MAIN_DB_PREFIX.'website_page WHERE rowid < '.$pageid.' AND fk_website = '.$object->id;
  1509. $resql = $db->query($sql);
  1510. if ($resql)
  1511. {
  1512. $obj = $db->fetch_object($resql);
  1513. if ($obj)
  1514. {
  1515. $pagepreviousid = $obj->pagepreviousid;
  1516. }
  1517. }
  1518. else dol_print_error($db);
  1519. $sql = 'SELECT MIN(rowid) as pagenextid FROM '.MAIN_DB_PREFIX.'website_page WHERE rowid > '.$pageid.' AND fk_website = '.$object->id;
  1520. $resql = $db->query($sql);
  1521. if ($resql)
  1522. {
  1523. $obj = $db->fetch_object($resql);
  1524. if ($obj)
  1525. {
  1526. $pagenextid = $obj->pagenextid;
  1527. }
  1528. }
  1529. else dol_print_error($db);
  1530. }
  1531. if ($pagepreviousid) print '<a class="valignmiddle" href="'.$_SERVER['PHP_SELF'].'?website='.urlencode($object->ref).'&pageid='.$pagepreviousid.'&action='.$action.'">'.img_previous($langs->trans("PreviousContainer")).'</a>';
  1532. else print '<span class="valignmiddle opacitymedium">'.img_previous($langs->trans("PreviousContainer")).'</span>';
  1533. if ($pagenextid) print '<a class="valignmiddle" href="'.$_SERVER['PHP_SELF'].'?website='.urlencode($object->ref).'&pageid='.$pagenextid.'&action='.$action.'">'.img_next($langs->trans("NextContainer")).'</a>';
  1534. else print '<span class="valignmiddle opacitymedium">'.img_next($langs->trans("NextContainer")).'</span>';
  1535. $websitepage = new WebSitePage($db);
  1536. if ($pageid > 0 && ($action == 'preview' || $action == 'createfromclone' || $action == 'createpagefromclone'))
  1537. {
  1538. $websitepage->fetch($pageid);
  1539. }
  1540. if ($action == 'preview' || $action == 'createfromclone' || $action == 'createpagefromclone')
  1541. {
  1542. $disabled='';
  1543. if (empty($user->rights->website->write)) $disabled=' disabled="disabled"';
  1544. // Confirmation to clone
  1545. if ($action == 'createfromclone') {
  1546. // Create an array for form
  1547. $formquestion = array(
  1548. array('type' => 'text', 'name' => 'siteref', 'label'=> $langs->trans("WebSite") ,'value'=> 'copy_of_'.$object->ref),
  1549. //array('type' => 'checkbox', 'name' => 'is_a_translation', 'label' => $langs->trans("SiteIsANewTranslation"), 'value' => 0),
  1550. //array('type' => 'other','name' => 'newlang','label' => $langs->trans("Language"), 'value' => $formadmin->select_language(GETPOST('newlang', 'az09')?GETPOST('newlang', 'az09'):$langs->defaultlang, 'newlang', 0, null, '', 0, 0, 'minwidth200')),
  1551. //array('type' => 'other','name' => 'newwebsite','label' => $langs->trans("WebSite"), 'value' => $formwebsite->selectWebsite($object->id, 'newwebsite', 0))
  1552. );
  1553. $formconfirm = $form->formconfirm($_SERVER["PHP_SELF"] . '?id='.$object->id, $langs->trans('CloneSite'), '', 'confirm_createfromclone', $formquestion, 0, 1, 200);
  1554. print $formconfirm;
  1555. }
  1556. if ($pageid > 0)
  1557. {
  1558. // Confirmation to clone
  1559. if ($action == 'createpagefromclone') {
  1560. // Create an array for form
  1561. $preselectedlanguage = GETPOST('newlang', 'az09') ? GETPOST('newlang', 'az09') : ($objectpage->lang ? $objectpage->lang : $langs->defaultlang);
  1562. $formquestion = array(
  1563. array('type' => 'text', 'tdclass'=>'maxwidth200', 'name' => 'pageurl', 'label'=> $langs->trans("WEBSITE_PAGENAME"), 'value'=> 'copy_of_'.$objectpage->pageurl),
  1564. array('type' => 'checkbox', 'tdclass'=>'maxwidth200', 'name' => 'is_a_translation', 'label' => $langs->trans("PageIsANewTranslation"), 'value' => 0),
  1565. array('type' => 'other','name' => 'newlang', 'label' => $langs->trans("Language"), 'value' => $formadmin->select_language($preselectedlanguage, 'newlang', 0, null, 1, 0, 0, 'minwidth200', 0, 1)),
  1566. array('type' => 'other','name' => 'newwebsite', 'label' => $langs->trans("WebSite"), 'value' => $formwebsite->selectWebsite($object->id, 'newwebsite', 0)),
  1567. );
  1568. $formconfirm = $form->formconfirm($_SERVER["PHP_SELF"] . '?website='.$object->ref.'&pageid=' . $pageid, $langs->trans('ClonePage'), '', 'confirm_createpagefromclone', $formquestion, 0, 1, 300, 550);
  1569. print $formconfirm;
  1570. }
  1571. print ' &nbsp; ';
  1572. print '<input type="submit" class="button nobordertransp"'.$disabled.' value="'.dol_escape_htmltag($langs->trans("EditPageMeta")).'" name="editmeta">';
  1573. print '<input type="submit" class="button nobordertransp"'.$disabled.' value="'.dol_escape_htmltag($langs->trans("EditHTMLSource")).'" name="editsource">';
  1574. if ($websitepage->grabbed_from)
  1575. {
  1576. //print '<input type="submit" class="button nobordertransp" disabled="disabled" title="'.dol_escape_htmltag($langs->trans("OnlyEditionOfSourceForGrabbedContent")).'" value="'.dol_escape_htmltag($langs->trans("EditWithEditor")).'" name="editcontent">';
  1577. print '<a class="button nobordertransp nohoverborder"'.$disabled.' href="#" disabled="disabled" title="'.dol_escape_htmltag($langs->trans("OnlyEditionOfSourceForGrabbedContent")).'">'.img_picto($langs->trans("EditInLineOff"),'switch_off','',false,0,0,'','nomarginleft').'</a>';
  1578. }
  1579. else
  1580. {
  1581. //print '<input type="submit" class="button nobordertransp"'.$disabled.' value="'.dol_escape_htmltag($langs->trans("EditWithEditor")).'" name="editcontent">';
  1582. if (empty($conf->global->WEBSITE_EDITINLINE))
  1583. {
  1584. print '<a class="button nobordertransp nohoverborder"'.$disabled.' href="'.$_SERVER["PHP_SELF"].'?website='.$object->ref.'&pageid='.$websitepage->id.'&action=seteditinline">'.img_picto($langs->trans("EditInLineOff"),'switch_off','',false,0,0,'','nomarginleft').'</a>';
  1585. }
  1586. else
  1587. {
  1588. print '<a class="button nobordertransp nohoverborder"'.$disabled.' href="'.$_SERVER["PHP_SELF"].'?website='.$object->ref.'&pageid='.$websitepage->id.'&action=unseteditinline">'.img_picto($langs->trans("EditInLineOn"),'switch_on','',false,0,0,'','nomarginleft').'</a>';
  1589. }
  1590. }
  1591. print ' &nbsp; ';
  1592. if ($object->fk_default_home > 0 && $pageid == $object->fk_default_home) print '<input type="submit" class="button nobordertransp" disabled="disabled" value="'.dol_escape_htmltag($langs->trans("SetAsHomePage")).'" name="setashome">';
  1593. else print '<input type="submit" class="button nobordertransp"'.$disabled.' value="'.dol_escape_htmltag($langs->trans("SetAsHomePage")).'" name="setashome">';
  1594. print '<input type="submit" class="button nobordertransp"'.$disabled.' value="'.dol_escape_htmltag($langs->trans("ClonePage")).'" name="createpagefromclone">';
  1595. print '<input type="submit" class="buttonDelete" name="delete" value="'.$langs->trans("Delete").'"'.($atleastonepage?'':' disabled="disabled"').'>';
  1596. }
  1597. }
  1598. print '</div>'; // end website selection
  1599. print '<div class="websitetools">';
  1600. if ($pageid > 0 && ($action == 'preview' || $action == 'createfromclone' || $action == 'createpagefromclone'))
  1601. {
  1602. $realpage=$urlwithroot.'/public/website/index.php?website='.$websitekey.'&pageref='.$websitepage->pageurl;
  1603. $pagealias = $websitepage->pageurl;
  1604. $htmltext = $langs->trans("PreviewSiteServedByDolibarr", $langs->transnoentitiesnoconv("Page"), $langs->transnoentitiesnoconv("Page"), $realpage, $dataroot);
  1605. $htmltext.='<br>'.$langs->trans("CheckVirtualHostPerms", $langs->transnoentitiesnoconv("ReadPerm"), DOL_DOCUMENT_ROOT);
  1606. $htmltext.='<br>'.$langs->trans("CheckVirtualHostPerms", $langs->transnoentitiesnoconv("WritePerm"), DOL_DATA_ROOT);
  1607. print '<a class="websitebuttonsitepreview" id="previewpage" href="'.$realpage.'&nocache='.dol_now().'" class="button" target="tab'.$websitekey.'" alt="'.dol_escape_htmltag($htmltext).'">';
  1608. print $form->textwithpicto('', $htmltext, 1, 'preview');
  1609. print '</a>'; // View page in new Tab
  1610. print '<div class="websiteinputurl" id="websiteinputpage">';
  1611. print '<input type="text" id="previewpageurl" class="minwidth200imp" name="previewsite" value="'.$pagealias.'" disabled="disabled">';
  1612. $htmltext=$langs->trans("PageNameAliasHelp", $langs->transnoentitiesnoconv("EditPageMeta"));
  1613. print $form->textwithpicto('', $htmltext, 1, 'help', '', 0, 2, 'helppagealias');
  1614. print '</div>';
  1615. $urlext=$virtualurl.'/'.$pagealias.'.php';
  1616. $urlint=$urlwithroot.'/public/website/index.php?website='.$websitekey;
  1617. $htmltext = $langs->trans("PreviewSiteServedByWebServer", $langs->transnoentitiesnoconv("Page"), $langs->transnoentitiesnoconv("Page"), $dataroot, $virtualurl?$urlext:'<span class="error">'.$langs->trans("VirtualHostUrlNotDefined").'</span>');
  1618. print '<a class="websitebuttonsitepreview'.($virtualurl?'':' websitebuttonsitepreviewdisabled cursornotallowed').'" id="previewpageext" href="'.$urlext.'" target="tab'.$websitekey.'ext" alt="'.dol_escape_htmltag($htmltext).'">';
  1619. print $form->textwithpicto('', $htmltext, 1, 'preview_ext');
  1620. print '</a>';
  1621. //print '<input type="submit" class="button" name="previewpage" target="tab'.$websitekey.'"value="'.$langs->trans("ViewPageInNewTab").'">';
  1622. // TODO Add js to save alias like we save virtual host name and use dynamic virtual host for url of id=previewpageext
  1623. }
  1624. if (! in_array($action, array('editcss','editmenu','file_manager','createsite','createcontainer','createpagefromclone')))
  1625. {
  1626. if (preg_match('/^create/',$action)) print '<input type="submit" id="savefile" class="button buttonforacesave" value="'.dol_escape_htmltag($langs->trans("Save")).'" name="update">';
  1627. if (preg_match('/^edit/',$action)) print '<input type="submit" id="savefile" class="button buttonforacesave" value="'.dol_escape_htmltag($langs->trans("Save")).'" name="update">';
  1628. if ($action != 'preview') print '<input type="submit" class="button" value="'.dol_escape_htmltag($langs->trans("Cancel")).'" name="preview">';
  1629. }
  1630. print '</div>'; // end websitetools
  1631. print '<div class="websitehelp">';
  1632. if (GETPOST('editsource', 'alpha') || GETPOST('editcontent', 'alpha'))
  1633. {
  1634. $htmltext=$langs->transnoentitiesnoconv("YouCanEditHtmlSource").'<br>';
  1635. print $form->textwithpicto($langs->trans("SyntaxHelp"), $htmltext, 1, 'help', 'inline-block', 1, 2, 'tooltipsubstitution');
  1636. }
  1637. print '</div>'; // end websitehelp
  1638. if ($action == 'preview' || $action == 'createfromclone' || $action == 'createpagefromclone')
  1639. {
  1640. // Adding jquery code to change on the fly url of preview ext
  1641. if (! empty($conf->use_javascript_ajax))
  1642. {
  1643. print '<script type="text/javascript" language="javascript">
  1644. jQuery(document).ready(function() {
  1645. jQuery("#websiteinputurl").keyup(function() {
  1646. console.log("Website external url modified "+jQuery("#previewsiteurl").val());
  1647. if (jQuery("#previewsiteurl").val() != "" && jQuery("#previewsiteurl").val().startsWith("http"))
  1648. {
  1649. jQuery("a.websitebuttonsitepreviewdisabled img").css({ opacity: 1 });
  1650. }
  1651. else jQuery("a.websitebuttonsitepreviewdisabled img").css({ opacity: 0.2 });
  1652. ';
  1653. print '
  1654. });
  1655. jQuery("#previewsiteext,#previewpageext").click(function() {
  1656. newurl=jQuery("#previewsiteurl").val();
  1657. if (! newurl.startsWith("http"))
  1658. {
  1659. alert(\''.dol_escape_js($langs->trans("ExternalURLMustStartWithHttp")).'\');
  1660. return false;
  1661. }
  1662. newpage=jQuery("#previewsiteurl").val() + "/" + jQuery("#previewpageurl").val() + ".php";
  1663. console.log("Open url "+newurl);
  1664. /* Save url */
  1665. jQuery.ajax({
  1666. method: "POST",
  1667. url: "'.DOL_URL_ROOT.'/core/ajax/saveinplace.php",
  1668. data: {
  1669. field: \'editval_virtualhost\',
  1670. element: \'website\',
  1671. table_element: \'website\',
  1672. fk_element: '.$object->id.',
  1673. value: newurl,
  1674. },
  1675. context: document.body
  1676. });
  1677. jQuery("#previewsiteext").attr("href",newurl);
  1678. jQuery("#previewpageext").attr("href",newpage);
  1679. });
  1680. });
  1681. </script>';
  1682. }
  1683. }
  1684. }
  1685. }
  1686. else
  1687. {
  1688. print '<div class="websiteselection">';
  1689. $langs->load("errors");
  1690. print $langs->trans("ErrorModuleSetupNotComplete");
  1691. print '<div>';
  1692. $action='';
  1693. }
  1694. print '</div>'; // end current websitebar
  1695. }
  1696. $head = array();
  1697. /*
  1698. * Edit Site HTML header and CSS
  1699. */
  1700. if ($action == 'editcss')
  1701. {
  1702. print '<div class="fiche">';
  1703. print '<br>';
  1704. if (GETPOST('editcss','alpha') || GETPOST('refreshpage','alpha'))
  1705. {
  1706. $csscontent = @file_get_contents($filecss);
  1707. // Clean the php css file to remove php code and get only css part
  1708. $csscontent = preg_replace('/<\?php \/\/ BEGIN PHP[^\?]*END PHP \?>\n*/ims', '', $csscontent);
  1709. }
  1710. else
  1711. {
  1712. $csscontent = GETPOST('WEBSITE_CSS_INLINE');
  1713. }
  1714. if (! trim($csscontent)) $csscontent='/* CSS content (all pages) */'."\n"."body.bodywebsite { margin: 0; font-family: 'Open Sans', sans-serif; }\n.bodywebsite h1 { margin-top: 0; margin-bottom: 0; padding: 10px;}";
  1715. if (GETPOST('editcss','alpha') || GETPOST('refreshpage','alpha'))
  1716. {
  1717. $jscontent = @file_get_contents($filejs);
  1718. // Clean the php js file to remove php code and get only js part
  1719. $jscontent = preg_replace('/<\?php \/\/ BEGIN PHP[^\?]*END PHP \?>\n*/ims', '', $jscontent);
  1720. }
  1721. else
  1722. {
  1723. $jscontent = GETPOST('WEBSITE_JS_INLINE');
  1724. }
  1725. if (! trim($jscontent)) $jscontent='/* JS content (all pages) */'."\n";
  1726. if (GETPOST('editcss','alpha') || GETPOST('refreshpage','alpha'))
  1727. {
  1728. $htmlheadercontent = @file_get_contents($filehtmlheader);
  1729. // Clean the php htmlheader file to remove php code and get only html part
  1730. $htmlheadercontent = preg_replace('/<\?php \/\/ BEGIN PHP[^\?]*END PHP \?>\n*/ims', '', $htmlheadercontent);
  1731. }
  1732. else
  1733. {
  1734. $htmlheadercontent = GETPOST('WEBSITE_HTML_HEADER');
  1735. }
  1736. if (! trim($htmlheadercontent))
  1737. {
  1738. $htmlheadercontent ="<html>\n";
  1739. $htmlheadercontent.=$htmlheadercontentdefault;
  1740. $htmlheadercontent.="</html>";
  1741. }
  1742. else
  1743. {
  1744. $htmlheadercontent = preg_replace('/^\s*<html>/ims', '', $htmlheadercontent);
  1745. $htmlheadercontent = preg_replace('/<\/html>\s*$/ims', '', $htmlheadercontent);
  1746. $htmlheadercontent='<html>'."\n".trim($htmlheadercontent)."\n".'</html>';
  1747. }
  1748. if (GETPOST('editcss','alpha') || GETPOST('refreshpage','alpha'))
  1749. {
  1750. $robotcontent = @file_get_contents($filerobot);
  1751. // Clean the php htmlheader file to remove php code and get only html part
  1752. $robotcontent = preg_replace('/<\?php \/\/ BEGIN PHP[^\?]*END PHP \?>\n*/ims', '', $robotcontent);
  1753. }
  1754. else
  1755. {
  1756. $robotcontent = GETPOST('WEBSITE_ROBOT');
  1757. }
  1758. if (! trim($robotcontent))
  1759. {
  1760. $robotcontent.="# Robot file. Generated with ".DOL_APPLICATION_TITLE."\n";
  1761. $robotcontent.="User-agent: *\n";
  1762. $robotcontent.="Allow: /public/\n";
  1763. $robotcontent.="Disallow: /administrator/\n";
  1764. }
  1765. if (GETPOST('editcss','alpha') || GETPOST('refreshpage','alpha'))
  1766. {
  1767. $htaccesscontent = @file_get_contents($filehtaccess);
  1768. // Clean the php htaccesscontent file to remove php code and get only html part
  1769. $htaccesscontent = preg_replace('/<\?php \/\/ BEGIN PHP[^\?]*END PHP \?>\n*/ims', '', $htaccesscontent);
  1770. }
  1771. else
  1772. {
  1773. $htaccesscontent = GETPOST('WEBSITE_HTACCESS');
  1774. }
  1775. if (! trim($htaccesscontent))
  1776. {
  1777. $htaccesscontent.="# Order allow,deny\n";
  1778. $htaccesscontent.="# Deny from all\n";
  1779. }
  1780. //else $htaccesscontent='<html>'."\n".$htaccesscontent."\n".'</html>';*/
  1781. dol_fiche_head();
  1782. print '<!-- Edit CSS -->'."\n";
  1783. print '<table class="border" width="100%">';
  1784. // Website
  1785. print '<tr><td class="titlefieldcreate">';
  1786. print $langs->trans('WebSite');
  1787. print '</td><td>';
  1788. print $websitekey;
  1789. print '</td></tr>';
  1790. // CSS file
  1791. print '<tr><td class="tdtop">';
  1792. print $langs->trans('WEBSITE_CSS_INLINE');
  1793. print '</td><td>';
  1794. $doleditor=new DolEditor('WEBSITE_CSS_INLINE', $csscontent, '', '220', 'ace', 'In', true, false, 'ace', 0, '100%', '');
  1795. print $doleditor->Create(1, '', true, 'CSS', 'css');
  1796. print '</td></tr>';
  1797. // JS file
  1798. print '<tr><td class="tdtop">';
  1799. print $langs->trans('WEBSITE_JS_INLINE');
  1800. print '</td><td>';
  1801. $doleditor=new DolEditor('WEBSITE_JS_INLINE', $jscontent, '', '220', 'ace', 'In', true, false, 'ace', 0, '100%', '');
  1802. print $doleditor->Create(1, '', true, 'JS', 'javascript');
  1803. print '</td></tr>';
  1804. // Common HTML header
  1805. print '<tr><td class="tdtop">';
  1806. $htmlhelp=$langs->trans("Example").' :<br>';
  1807. $htmlhelp.=dol_htmlentitiesbr($htmlheadercontentdefault);
  1808. print $form->textwithpicto($langs->trans('WEBSITE_HTML_HEADER'), $htmlhelp, 1, 'help', '', 0, 2, 'htmlheadertooltip');
  1809. print '</td><td>';
  1810. $doleditor=new DolEditor('WEBSITE_HTML_HEADER', $htmlheadercontent, '', '220', 'ace', 'In', true, false, 'ace', 0, '100%', '');
  1811. print $doleditor->Create(1, '', true, 'HTML Header', 'html');
  1812. print '</td></tr>';
  1813. // Robot file
  1814. print '<tr><td class="tdtop">';
  1815. print $langs->trans('WEBSITE_ROBOT');
  1816. print '</td><td>';
  1817. $doleditor=new DolEditor('WEBSITE_ROBOT', $robotcontent, '', '220', 'ace', 'In', true, false, 'ace', 0, '100%', '');
  1818. print $doleditor->Create(1, '', true, 'Robot file', 'text');
  1819. print '</td></tr>';
  1820. // .htaccess
  1821. print '<tr><td class="tdtop">';
  1822. print $langs->trans('WEBSITE_HTACCESS');
  1823. print '</td><td>';
  1824. $doleditor=new DolEditor('WEBSITE_HTACCESS', $htaccesscontent, '', '220', 'ace', 'In', true, false, 'ace', 0, '100%', '');
  1825. print $doleditor->Create(1, '', true, $langs->trans("File").' .htaccess', 'text');
  1826. print '</td></tr>';
  1827. print '</table>';
  1828. dol_fiche_end();
  1829. print '</div>';
  1830. print '<br>';
  1831. }
  1832. if ($action == 'createsite')
  1833. {
  1834. print '<div class="fiche">';
  1835. print '<br>';
  1836. /*$h = 0;
  1837. $head = array();
  1838. $head[$h][0] = dol_buildpath('/website/index.php',1).'?id='.$object->id;
  1839. $head[$h][1] = $langs->trans("AddSite");
  1840. $head[$h][2] = 'card';
  1841. $h++;
  1842. dol_fiche_head($head, 'card', $langs->trans("AddSite"), -1, 'globe');
  1843. */
  1844. if ($action == 'createcontainer') print_fiche_titre($langs->trans("AddSite"));
  1845. print '<!-- Add site -->'."\n";
  1846. //print '<div class="fichecenter">';
  1847. print '<table class="border" width="100%">';
  1848. if (GETPOST('WEBSITE_REF')) $siteref=GETPOST('WEBSITE_REF','alpha');
  1849. if (GETPOST('WEBSITE_DESCRIPTION')) $sitedesc=GETPOST('WEBSITE_DESCRIPTION','alpha');
  1850. print '<tr><td class="titlefieldcreate fieldrequired">';
  1851. print $langs->trans('Ref');
  1852. print '</td><td>';
  1853. print '<input type="text" class="flat maxwidth300" name="WEBSITE_REF" value="'.dol_escape_htmltag($siteref).'">';
  1854. print '</td></tr>';
  1855. print '<tr><td>';
  1856. print $langs->trans('Description');
  1857. print '</td><td>';
  1858. print '<input type="text" class="flat minwidth300" name="WEBSITE_DESCRIPTION" value="'.dol_escape_htmltag($sitedesc).'">';
  1859. print '</td></tr>';
  1860. print '<tr><td>';
  1861. $htmltext = $langs->trans("SetHereVirtualHost", DOL_DATA_ROOT.'/website/<i>websiteref</i>');
  1862. $htmltext.='<br>';
  1863. $htmltext.='<br>'.$langs->trans("CheckVirtualHostPerms", $langs->transnoentitiesnoconv("ReadPerm"), DOL_DOCUMENT_ROOT);
  1864. $htmltext.='<br>'.$langs->trans("CheckVirtualHostPerms", $langs->transnoentitiesnoconv("WritePerm"), DOL_DATA_ROOT);
  1865. print $form->textwithpicto($langs->trans('Virtualhost'), $htmltext, 1, 'help', '', 0, 2, 'tooltipvirtual');
  1866. print '</td><td>';
  1867. print '<input type="text" class="flat minwidth300" name="WEBSITE_DESCRIPTION" value="'.dol_escape_htmltag($sitedesc).'">';
  1868. print '</td></tr>';
  1869. print '</table>';
  1870. if ($action == 'createsite')
  1871. {
  1872. print '<div class="center">';
  1873. print '<input class="button" type="submit" name="addcontainer" value="'.$langs->trans("Create").'">';
  1874. print '<input class="button" type="submit" name="preview" value="'.$langs->trans("Cancel").'">';
  1875. print '</div>';
  1876. }
  1877. //print '</div>';
  1878. //dol_fiche_end();
  1879. print '</div>';
  1880. print '<br>';
  1881. }
  1882. if ($action == 'importsite')
  1883. {
  1884. print '<div class="fiche">';
  1885. print '<br>';
  1886. print_fiche_titre($langs->trans("ImportSite"));
  1887. dol_fiche_head(array(), '0', '', -1);
  1888. print $langs->trans("ZipOfWebsitePackageToImport").'<br><br>';
  1889. print '<input class="flat minwidth400" type="file" name="userfile[]" accept=".zip">';
  1890. print '<input type="submit" class="button" name="buttonsubmitimportfile" value="'.dol_escape_htmltag($langs->trans("Upload")).'">';
  1891. dol_fiche_end();
  1892. print '</div>';
  1893. print '<br>';
  1894. }
  1895. if ($action == 'editmeta' || $action == 'createcontainer')
  1896. {
  1897. print '<div class="fiche">';
  1898. print '<br>';
  1899. /*$h = 0;
  1900. $head = array();
  1901. $head[$h][0] = dol_buildpath('/website/index.php',1).'?id='.$object->id;
  1902. $head[$h][1] = $langs->trans("AddPage");
  1903. $head[$h][2] = 'card';
  1904. $h++;
  1905. dol_fiche_head($head, 'card', $langs->trans("AddPage"), -1, 'globe');
  1906. */
  1907. if ($action == 'createcontainer') print_fiche_titre($langs->trans("AddPage"));
  1908. print '<!-- Edit or create page/container -->'."\n";
  1909. //print '<div class="fichecenter">';
  1910. if ($action == 'createcontainer')
  1911. {
  1912. print '<br>';
  1913. print ' * '.$langs->trans("CreateByFetchingExternalPage").'<br><hr>';
  1914. print '<table class="border" width="100%">';
  1915. print '<tr><td class="titlefield">';
  1916. print $langs->trans("URL");
  1917. print '</td><td>';
  1918. print '<input class="flat minwidth300" type="text" name="externalurl" value="'.dol_escape_htmltag(GETPOST('externalurl','alpha')).'" placeholder="https://externalsite/pagetofetch"> ';
  1919. print '<input class="flat paddingtop" type="checkbox" name="grabimages" value="1" checked="checked"> '.$langs->trans("GrabImagesInto");
  1920. print ' ';
  1921. print $langs->trans("ImagesShouldBeSavedInto").' ';
  1922. $arraygrabimagesinto=array('root'=>$langs->trans("WebsiteRootOfImages"), 'subpage'=>$langs->trans("SubdirOfPage"));
  1923. print $form->selectarray('grabimagesinto', $arraygrabimagesinto, GETPOSTISSET('grabimagesinto')?GETPOST('grabimagesinto'):'root');
  1924. print '<br>';
  1925. print '<input class="button" style="margin-top: 5px" type="submit" name="fetchexternalurl" value="'.dol_escape_htmltag($langs->trans("FetchAndCreate")).'">';
  1926. print '<br>'.info_admin($langs->trans("OnlyEditionOfSourceForGrabbedContentFuture"), 0, 0, '1');
  1927. print '</td></tr>';
  1928. print '</table>';
  1929. print '<br>';
  1930. print ' * '.$langs->trans("OrEnterPageInfoManually").'<br><hr>';
  1931. }
  1932. print '<table class="border" width="100%">';
  1933. if ($action != 'createcontainer')
  1934. {
  1935. print '<tr><td class="titlefield">';
  1936. print $langs->trans('IDOfPage');
  1937. print '</td><td>';
  1938. print $pageid;
  1939. print '</td></tr>';
  1940. print '<tr><td class="titlefield">';
  1941. print $langs->trans('WEBSITE_PAGEURL');
  1942. print '</td><td>';
  1943. print '/public/website/index.php?website='.urlencode($websitekey).'&pageid='.urlencode($pageid);
  1944. print '</td></tr>';
  1945. /*
  1946. print '<tr><td class="titlefield">';
  1947. print $langs->trans('InitiallyGrabbedFrom');
  1948. print '</td><td>';
  1949. print $objectpage->grabbed_from;
  1950. print '</td></tr>';
  1951. */
  1952. $type_container=$objectpage->type_container;
  1953. $pageurl=$objectpage->pageurl;
  1954. $pagealiasalt=$objectpage->aliasalt;
  1955. $pagetitle=$objectpage->title;
  1956. $pagedescription=$objectpage->description;
  1957. $pagekeywords=$objectpage->keywords;
  1958. $pagelang=$objectpage->lang;
  1959. $pagehtmlheader=$objectpage->htmlheader;
  1960. }
  1961. else
  1962. {
  1963. $type_container = 'page';
  1964. }
  1965. if (GETPOST('WEBSITE_TITLE','alpha')) $pagetitle=GETPOST('WEBSITE_TITLE','alpha');
  1966. if (GETPOST('WEBSITE_PAGENAME','alpha')) $pageurl=GETPOST('WEBSITE_PAGENAME','alpha');
  1967. if (GETPOST('WEBSITE_ALIASALT','alpha')) $pagealiasalt=GETPOST('WEBSITE_ALIASALT','alpha');
  1968. if (GETPOST('WEBSITE_DESCRIPTION','alpha')) $pagedescription=GETPOST('WEBSITE_DESCRIPTION','alpha');
  1969. if (GETPOST('WEBSITE_KEYWORDS','alpha')) $pagekeywords=GETPOST('WEBSITE_KEYWORDS','alpha');
  1970. if (GETPOST('WEBSITE_LANG','aZ09')) $pagelang=GETPOST('WEBSITE_LANG','aZ09');
  1971. if (GETPOST('htmlheader','none')) $pagehtmlheader=GETPOST('htmlheader','none');
  1972. // Title
  1973. print '<tr><td class="fieldrequired">';
  1974. print $langs->trans('WEBSITE_TITLE');
  1975. print '</td><td>';
  1976. print '<input type="text" class="flat quatrevingtpercent" name="WEBSITE_TITLE" id="WEBSITE_TITLE" value="'.dol_escape_htmltag($pagetitle).'">';
  1977. print '</td></tr>';
  1978. // Alias
  1979. print '<tr><td class="titlefieldcreate fieldrequired">';
  1980. print $langs->trans('WEBSITE_PAGENAME');
  1981. print '</td><td>';
  1982. print '<input type="text" class="flat minwidth300" name="WEBSITE_PAGENAME" id="WEBSITE_PAGENAME" value="'.dol_escape_htmltag($pageurl).'">';
  1983. print '</td></tr>';
  1984. print '<tr><td class="titlefield fieldrequired">';
  1985. print $langs->trans('WEBSITE_TYPE_CONTAINER');
  1986. print '</td><td>';
  1987. print $formwebsite->selectTypeOfContainer('WEBSITE_TYPE_CONTAINER', (GETPOST('WEBSITE_TYPE_CONTAINER','alpha')?GETPOST('WEBSITE_TYPE_CONTAINER','alpha'):$type_container));
  1988. print '</td></tr>';
  1989. if ($action == 'createcontainer')
  1990. {
  1991. print '<tr><td class="titlefield fieldrequired">';
  1992. print $langs->trans('WEBSITE_PAGE_EXAMPLE');
  1993. print '</td><td>';
  1994. print $formwebsite->selectSampleOfContainer('sample', (GETPOST('sample','alpha')?GETPOST('sample','alpha'):'corporatehomepage'));
  1995. print '</td></tr>';
  1996. }
  1997. print '<tr><td>';
  1998. print $langs->trans('WEBSITE_DESCRIPTION');
  1999. print '</td><td>';
  2000. print '<input type="text" class="flat quatrevingtpercent" name="WEBSITE_DESCRIPTION" value="'.dol_escape_htmltag($pagedescription).'">';
  2001. print '</td></tr>';
  2002. print '<tr><td>';
  2003. print $langs->trans('WEBSITE_KEYWORDS');
  2004. print '</td><td>';
  2005. print '<input type="text" class="flat quatrevingtpercent" name="WEBSITE_KEYWORDS" value="'.dol_escape_htmltag($pagekeywords).'">';
  2006. print '</td></tr>';
  2007. print '<tr><td>';
  2008. print $langs->trans('Language');
  2009. print '</td><td>';
  2010. print $formadmin->select_language($pagelang?$pagelang:$langs->defaultlang, 'WEBSITE_LANG', 0, null, '1');
  2011. print '</td></tr>';
  2012. print '<tr><td class="titlefieldcreate">';
  2013. $htmlhelp=$langs->trans("WEBSITE_ALIASALTDesc");
  2014. print $form->textwithpicto($langs->trans('WEBSITE_ALIASALT'), $htmlhelp, 1, 'help', '', 0, 2, 'htmlheadertooltip');
  2015. print '</td><td>';
  2016. print '<input type="text" class="flat minwidth300" name="WEBSITE_ALIASALT" value="'.dol_escape_htmltag($pagealiasalt).'">';
  2017. print '</td></tr>';
  2018. print '<tr><td class="tdhtmlheader tdtop">';
  2019. $htmlhelp=$langs->trans("EditTheWebSiteForACommonHeader").'<br><br>';
  2020. $htmlhelp=$langs->trans("Example").' :<br>';
  2021. $htmlhelp.=dol_htmlentitiesbr($htmlheadercontentdefault);
  2022. print $form->textwithpicto($langs->trans('HtmlHeaderPage'), $htmlhelp, 1, 'help', '', 0, 2, 'htmlheadertooltip');
  2023. print '</td><td>';
  2024. $doleditor=new DolEditor('htmlheader', $pagehtmlheader, '', '180', 'ace', 'In', true, false, 'ace', 0, '100%', '');
  2025. print $doleditor->Create(1, '', true, 'HTML Header', 'html');
  2026. print '</td></tr>';
  2027. print '</table>';
  2028. if ($action == 'createcontainer')
  2029. {
  2030. print '<div class="center">';
  2031. print '<input class="button" type="submit" name="addcontainer" value="'.$langs->trans("Create").'">';
  2032. print '<input class="button" type="submit" name="preview" value="'.$langs->trans("Cancel").'">';
  2033. print '</div>';
  2034. }
  2035. if ($action == 'createcontainer')
  2036. {
  2037. print '<script type="text/javascript" language="javascript">
  2038. jQuery(document).ready(function() {
  2039. var disableautofillofalias = 0;
  2040. jQuery("#WEBSITE_TITLE").keyup(function() {
  2041. if (disableautofillofalias == 0)
  2042. {
  2043. var valnospecial = jQuery("#WEBSITE_TITLE").val().replace(/[^\w]/gi, \'-\').toLowerCase();
  2044. valnospecial = valnospecial.replace(/\-+/g, \'-\').replace(/\-$/, \'\');
  2045. console.log("disableautofillofalias=0 so we replace WEBSITE_TITLE with "+valnospecial);
  2046. jQuery("#WEBSITE_PAGENAME").val(valnospecial);
  2047. }
  2048. });
  2049. jQuery("#WEBSITE_PAGENAME").keyup(function() {
  2050. disableautofillofalias = 1;
  2051. });
  2052. });
  2053. </script>';
  2054. }
  2055. //print '</div>';
  2056. //dol_fiche_end();
  2057. print '</div>';
  2058. print '<br>';
  2059. }
  2060. if ($action == 'editfile' || $action == 'file_manager')
  2061. {
  2062. print '<!-- Edit Media -->'."\n";
  2063. print '<div class="fiche"><br><br>';
  2064. //print '<div class="center">'.$langs->trans("FeatureNotYetAvailable").'</center>';
  2065. $module = 'medias';
  2066. if (empty($url)) $url=DOL_URL_ROOT.'/website/index.php'; // Must be an url without param
  2067. include DOL_DOCUMENT_ROOT.'/core/tpl/filemanager.tpl.php';
  2068. print '</div>';
  2069. }
  2070. if ($action == 'editmenu')
  2071. {
  2072. print '<!-- Edit Menu -->'."\n";
  2073. print '<div class="center">'.$langs->trans("FeatureNotYetAvailable").'</center>';
  2074. }
  2075. if ($action == 'editsource')
  2076. {
  2077. /*
  2078. * Editing with source editor
  2079. */
  2080. $contentforedit = '';
  2081. /*$contentforedit.='<style scoped>'."\n"; // "scoped" means "apply to parent element only". Not yet supported by browsers
  2082. $contentforedit.=$csscontent;
  2083. $contentforedit.='</style>'."\n";*/
  2084. $contentforedit .= $objectpage->content;
  2085. require_once DOL_DOCUMENT_ROOT.'/core/class/doleditor.class.php';
  2086. $doleditor=new DolEditor('PAGE_CONTENT',$contentforedit,'',500,'Full','',true,true,'ace',ROWS_5,'90%');
  2087. $doleditor->Create(0, '', false, 'HTML Source', 'php');
  2088. }
  2089. if ($action == 'editcontent')
  2090. {
  2091. /*
  2092. * Editing with default ckeditor
  2093. */
  2094. $contentforedit = '';
  2095. /*$contentforedit.='<style scoped>'."\n"; // "scoped" means "apply to parent element only". Not yet supported by browsers
  2096. $contentforedit.=$csscontent;
  2097. $contentforedit.='</style>'."\n";*/
  2098. $contentforedit .= $objectpage->content;
  2099. $contentforedit = preg_replace('/(<img.*src=")(?!http)/', '\1'.DOL_URL_ROOT.'/viewimage.php?modulepart=medias&file=', $contentforedit, -1, $nbrep);
  2100. require_once DOL_DOCUMENT_ROOT.'/core/class/doleditor.class.php';
  2101. $doleditor=new DolEditor('PAGE_CONTENT',$contentforedit,'',500,'Full','',true,true,true,ROWS_5,'90%');
  2102. $doleditor->Create(0, '', false);
  2103. }
  2104. print "</div>\n</form>\n";
  2105. if ($action == 'preview' || $action == 'createfromclone' || $action == 'createpagefromclone')
  2106. {
  2107. if ($pageid > 0)
  2108. {
  2109. // $filejs
  2110. // $filecss
  2111. // $filephp
  2112. // Ouput page under the Dolibarr top menu
  2113. $objectpage->fetch($pageid);
  2114. $jscontent = @file_get_contents($filejs);
  2115. $out = '<!-- Page content '.$filetpl.' : Div with (CSS Of website from file + Style/htmlheader of page from database + Page content from database) -->'."\n";
  2116. // Include a html so we can benefit of the header of page.
  2117. // Note: We can't use iframe as it can be used to include another external html file
  2118. // Note: We can't use frame as it is deprecated.
  2119. $out.="\n<html><head>\n";
  2120. $out.=dolWebsiteReplacementOfLinks($object, $objectpage->htmlheader, 1);
  2121. $out.="</head>\n";
  2122. $out.="\n<body>";
  2123. $out.='<div id="websitecontentundertopmenu" class="websitecontentundertopmenu">'."\n";
  2124. // REPLACEMENT OF LINKS When page called by website editor
  2125. $out.='<style scoped>'."\n"; // "scoped" means "apply to parent element only". No more supported by browsers, snif !
  2126. $tmpout='';
  2127. $tmpout.= '/* Include website CSS file */'."\n";
  2128. //$csscontent = @file_get_contents($filecss);
  2129. ob_start();
  2130. include $filecss;
  2131. $csscontent = ob_get_contents();
  2132. ob_end_clean();
  2133. $tmpout.= dolWebsiteReplacementOfLinks($object, $csscontent, 1);
  2134. $tmpout.= '/* Include style from the HTML header of page */'."\n";
  2135. // Clean the html header of page to get only <style> content
  2136. $tmp = preg_split('(<style[^>]*>|</style>)', $objectpage->htmlheader);
  2137. $tmpstyleinheader ='';
  2138. $i=0;
  2139. foreach($tmp as $valtmp)
  2140. {
  2141. $i++;
  2142. if ($i % 2 == 0) $tmpstyleinheader.=$valtmp."\n";
  2143. }
  2144. $tmpout.= $tmpstyleinheader."\n";
  2145. // Clean style that may affect global style of Dolibarr
  2146. $tmpout=preg_replace('/}[\s\n]*body\s*{[^}]+}/ims','}',$tmpout);
  2147. $out.=$tmpout;
  2148. $out.='</style>'."\n";
  2149. // Note: <div> or <section> with contenteditable="true" inside this can be edited with inline ckeditor
  2150. // Do not enable the contenteditable when page was grabbed, ckeditor is removing span and adding borders,
  2151. // so editable will be available only from container created from scratch
  2152. //$out.='<div id="bodywebsite" class="bodywebsite"'.($objectpage->grabbed_from ? ' contenteditable="true"' : '').'>'."\n";
  2153. $out.='<div id="bodywebsite" class="bodywebsite">'."\n";
  2154. // TODO Add the contenteditable="true" when mode Edit Inline is on
  2155. $newcontent = $objectpage->content;
  2156. if (empty($conf->global->WEBSITE_EDITINLINE))
  2157. {
  2158. $newcontent = preg_replace('/(div|section)(\s[^\>]*)contenteditable="true"/', '\1\2', $newcontent);
  2159. }
  2160. else
  2161. {
  2162. }
  2163. /*
  2164. $filephp = $objectpage->
  2165. ob_start();
  2166. include $filephp;
  2167. $newcontent = ob_get_contents();
  2168. ob_end_clean();
  2169. */
  2170. $out.=dolWebsiteReplacementOfLinks($object, $newcontent)."\n";
  2171. $out.='</div>';
  2172. $out.='</div> <!-- End div id=websitecontentundertopmenu -->';
  2173. /*if ($includepageintoaframeoradiv == 'iframe')
  2174. {
  2175. $out .= "</body></html></iframe>";
  2176. }*/
  2177. $out .= "\n</body></html>\n";
  2178. $out.= "\n".'<!-- End page content '.$filetpl.' -->'."\n\n";
  2179. // For jqueryscoped (does not work as expected)
  2180. //$out.="<script>$.scoped();</script>";
  2181. print $out;
  2182. /*file_put_contents($filetpl, $out);
  2183. if (! empty($conf->global->MAIN_UMASK))
  2184. @chmod($filetpl, octdec($conf->global->MAIN_UMASK));
  2185. // Output file on browser
  2186. dol_syslog("index.php include $filetpl $filename content-type=$type");
  2187. $original_file_osencoded=dol_osencode($filetpl); // New file name encoded in OS encoding charset
  2188. // This test if file exists should be useless. We keep it to find bug more easily
  2189. if (! file_exists($original_file_osencoded))
  2190. {
  2191. dol_print_error(0,$langs->trans("ErrorFileDoesNotExists",$original_file));
  2192. exit;
  2193. }
  2194. //include_once $original_file_osencoded;
  2195. */
  2196. /*print '<iframe class="websiteiframenoborder centpercent" src="'.DOL_URL_ROOT.'/public/website/index.php?website='.$websitekey.'&pageid='.$pageid.'"/>';
  2197. print '</iframe>';*/
  2198. }
  2199. else
  2200. {
  2201. print '<br><br><div class="center">'.$langs->trans("PreviewOfSiteNotYetAvailable", $object->ref).'</center><br><br><br>';
  2202. print '<div class="center"><div class="logo_setup"></div></div>';
  2203. }
  2204. }
  2205. // End of page
  2206. llxFooter();
  2207. $db->close();