index.php 49 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313
  1. <?php
  2. //Set some variables
  3. ini_set("display_errors", 1);
  4. ini_set("error_reporting", E_ALL | E_STRICT);
  5. date_default_timezone_set('America/Los_Angeles');
  6. $data = false;
  7. $databaseLocation = "databaseLocation.ini.php";
  8. $needSetup = "Yes";
  9. $tabSetup = "Yes";
  10. $hasOptions = "No";
  11. $settingsicon = "No";
  12. $settingsActive = "";
  13. $action = "";
  14. $title = "Organizr";
  15. $topbar = "#eb6363";
  16. $topbartext = "#FFFFFF";
  17. $bottombar = "#eb6363";
  18. $sidebar = "#000000";
  19. $hoverbg = "#eb6363";
  20. $activetabBG = "#eb6363";
  21. $activetabicon = "#FFFFFF";
  22. $activetabtext = "#FFFFFF";
  23. $inactiveicon = "#FFFFFF";
  24. $inactivetext = "#FFFFFF";
  25. $baseURL = "";
  26. function registration_callback($username, $email, $userdir){
  27. global $data;
  28. $data = array($username, $email, $userdir);
  29. }
  30. function printArray($arrayName){
  31. foreach ( $arrayName as $item ) :
  32. echo $item . "<br/>";
  33. endforeach;
  34. }
  35. function write_ini_file($content, $path) {
  36. if (!$handle = fopen($path, 'w')) {
  37. return false;
  38. }
  39. $success = fwrite($handle, $content);
  40. fclose($handle);
  41. return $success;
  42. }
  43. if(isset($_POST['action'])) :
  44. $action = $_POST['action'];
  45. endif;
  46. if($action == "createLocation") :
  47. $databaseData = '; <?php die("Access denied"); ?>' . "\r\n";
  48. foreach ($_POST as $postName => $postValue) {
  49. if($postName !== "action") :
  50. if(substr($postValue, -1) == "/") : $postValue = rtrim($postValue, "/"); endif;
  51. $databaseData .= $postName . " = \"" . $postValue . "\"\r\n";
  52. endif;
  53. }
  54. write_ini_file($databaseData, $databaseLocation);
  55. endif;
  56. if(!file_exists($databaseLocation)) :
  57. $configReady = "No";
  58. $userpic = "";
  59. else :
  60. $configReady = "Yes";
  61. require_once("user.php");
  62. $USER = new User("registration_callback");
  63. $dbfile = DATABASE_LOCATION . constant('User::DATABASE_NAME') . ".db";
  64. $database = new PDO("sqlite:" . $dbfile);
  65. $query = "SELECT * FROM users";
  66. foreach($database->query($query) as $data) {
  67. $needSetup = "No";
  68. }
  69. $db = DATABASE_LOCATION . constant('User::DATABASE_NAME') . ".db";
  70. $file_db = new PDO("sqlite:" . $db);
  71. $file_db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  72. $dbTab = $file_db->query('SELECT name FROM sqlite_master WHERE type="table" AND name="tabs"');
  73. $dbOptions = $file_db->query('SELECT name FROM sqlite_master WHERE type="table" AND name="options"');
  74. foreach($dbTab as $row) :
  75. if (in_array("tabs", $row)) :
  76. $tabSetup = "No";
  77. endif;
  78. endforeach;
  79. if($tabSetup == "Yes") :
  80. $settingsActive = "active";
  81. endif;
  82. foreach($dbOptions as $row) :
  83. if (in_array("options", $row)) :
  84. $hasOptions = "Yes";
  85. endif;
  86. endforeach;
  87. if($tabSetup == "No") :
  88. if($USER->authenticated && $USER->role == "admin") :
  89. $result = $file_db->query('SELECT * FROM tabs WHERE active = "true"');
  90. $getsettings = $file_db->query('SELECT * FROM tabs WHERE active = "true"');
  91. foreach($getsettings as $row) :
  92. if(!empty($row['iconurl']) && $settingsicon == "No") :
  93. $settingsicon = "Yes";
  94. endif;
  95. endforeach;
  96. elseif($USER->authenticated && $USER->role == "user") :
  97. $result = $file_db->query('SELECT * FROM tabs WHERE active = "true" AND user = "true"');
  98. else :
  99. $result = $file_db->query('SELECT * FROM tabs WHERE active = "true" AND guest = "true"');
  100. endif;
  101. endif;
  102. if($hasOptions == "Yes") :
  103. $resulto = $file_db->query('SELECT * FROM options');
  104. foreach($resulto as $row) :
  105. $title = $row['title'];
  106. $topbartext = $row['topbartext'];
  107. $topbar = $row['topbar'];
  108. $bottombar = $row['bottombar'];
  109. $sidebar = $row['sidebar'];
  110. $hoverbg = $row['hoverbg'];
  111. $activetabBG = $row['activetabBG'];
  112. $activetabicon = $row['activetabicon'];
  113. $activetabtext = $row['activetabtext'];
  114. $inactiveicon = $row['inactiveicon'];
  115. $inactivetext = $row['inactivetext'];
  116. endforeach;
  117. endif;
  118. $userpic = md5( strtolower( trim( $USER->email ) ) );
  119. endif;
  120. ?>
  121. <!DOCTYPE html>
  122. <html lang="en" class="no-js">
  123. <head>
  124. <meta charset="UTF-8">
  125. <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no"/>
  126. <meta name="apple-mobile-web-app-capable" content="yes" />
  127. <meta name="mobile-web-app-capable" content="yes" /
  128. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  129. <meta name="msapplication-tap-highlight" content="no" />
  130. <title><?=$title;?><?php if($title !== "Organizr") : echo "- Organizr"; endif; ?></title>
  131. <link rel="stylesheet" href="<?=$baseURL;?>bower_components/bootstrap/dist/css/bootstrap.min.css">
  132. <link rel="stylesheet" href="<?=$baseURL;?>bower_components/font-awesome/css/font-awesome.min.css">
  133. <link rel="stylesheet" href="<?=$baseURL;?>bower_components/mdi/css/materialdesignicons.min.css">
  134. <link rel="stylesheet" href="<?=$baseURL;?>bower_components/metisMenu/dist/metisMenu.min.css">
  135. <link rel="stylesheet" href="<?=$baseURL;?>bower_components/Waves/dist/waves.min.css">
  136. <link rel="stylesheet" href="<?=$baseURL;?>bower_components/malihu-custom-scrollbar-plugin/jquery.mCustomScrollbar.css">
  137. <link rel="stylesheet" href="<?=$baseURL;?>js/selects/cs-select.css">
  138. <link rel="stylesheet" href="<?=$baseURL;?>js/selects/cs-skin-elastic.css">
  139. <link rel="stylesheet" href="<?=$baseURL;?>bower_components/google-material-color/dist/palette.css">
  140. <link rel="stylesheet" href="<?=$baseURL;?>bower_components/sweetalert/dist/sweetalert.css">
  141. <link rel="stylesheet" href="<?=$baseURL;?>bower_components/smoke/dist/css/smoke.min.css">
  142. <script src="<?=$baseURL;?>js/menu/modernizr.custom.js"></script>
  143. <script type="text/javascript" src="<?=$baseURL;?>js/sha1.js"></script>
  144. <script type="text/javascript" src="<?=$baseURL;?>js/user.js"></script>
  145. <link rel="stylesheet" href="<?=$baseURL;?>css/style.css">
  146. <link rel="apple-touch-icon" sizes="180x180" href="<?=$baseURL;?>images/favicon/apple-touch-icon.png">
  147. <link rel="icon" type="image/png" href="<?=$baseURL;?>images/favicon/favicon-32x32.png" sizes="32x32">
  148. <link rel="icon" type="image/png" href="<?=$baseURL;?>images/favicon/favicon-16x16.png" sizes="16x16">
  149. <link rel="manifest" href="<?=$baseURL;?>images/favicon/manifest.json">
  150. <link rel="mask-icon" href="<?=$baseURL;?>images/favicon/safari-pinned-tab.svg" color="#2d89ef">
  151. <link rel="shortcut icon" href="<?=$baseURL;?>images/favicon/favicon.ico">
  152. <meta name="msapplication-config" content="<?=$baseURL;?>images/favicon/browserconfig.xml">
  153. <meta name="theme-color" content="#2d89ef">
  154. <link rel="stylesheet" type="text/css" href="css/addtohomescreen.css">
  155. <script src="js/addtohomescreen.js"></script>
  156. <!--[if lt IE 9]>
  157. <script src="bower_components/html5shiv/dist/html5shiv.min.js"></script>
  158. <script src="bower_components/respondJs/dest/respond.min.js"></script>
  159. <![endif]-->
  160. </head>
  161. <body style="overflow: hidden">
  162. <!--Preloader-->
  163. <div id="preloader" class="preloader table-wrapper">
  164. <div class="table-row">
  165. <div class="table-cell">
  166. <div class="la-ball-scale-multiple la-3x" style="color: <?=$topbar;?>">
  167. <div></div>
  168. <div></div>
  169. <div></div>
  170. <logo class="logo"><img height="192px" src="images/organizr.png"></logo>
  171. </div>
  172. </div>
  173. </div>
  174. </div>
  175. <div id="main-wrapper" class="main-wrapper">
  176. <style>
  177. .bottom-bnts a {
  178. background: <?=$bottombar;?>;
  179. color: <?=$topbartext;?>;
  180. }.bottom-bnts {
  181. background-color: <?=$bottombar;?>;
  182. }.gn-menu-main {
  183. background-color: <?=$topbar;?>;
  184. }.gn-menu-main ul.gn-menu {
  185. background: <?=$sidebar;?>;
  186. }.gn-menu-wrapper {
  187. background: <?=$sidebar;?>;
  188. }.gn-menu i {
  189. height: 18px;
  190. width: 52px;
  191. }.la-timer.la-dark {
  192. color: <?=$topbartext;?>
  193. }.refresh-preloader {
  194. background: <?=$topbartext;?>;
  195. }.la-timer {
  196. width: 75px;
  197. height: 75px;
  198. padding-top: 20px;
  199. border-radius: 100px;
  200. background: <?=$sidebar;?>;
  201. border: 2px solid <?=$topbar;?>;
  202. }@media screen and (min-width:737px){
  203. .tab-item:hover a {
  204. color: <?=$sidebar;?> !important;
  205. background: <?=$hoverbg;?>;
  206. border-radius: 100px 0 0 100px;
  207. }
  208. }.gn-menu li.active > a {
  209. color: <?=$activetabtext;?> !important;
  210. background: <?=$activetabBG;?>;
  211. border-radius: 100px 0 0 100px;
  212. }.active {
  213. display: block;
  214. }.hidden {
  215. display: none;
  216. }.errorz {
  217. background-image: linear-gradient(red, red), linear-gradient(#d2d2d2, #d2d2d2);
  218. outline: none;
  219. animation: input-highlight .5s forwards;
  220. box-shadow: none;
  221. padding-left: 0;
  222. border: 0;
  223. border-radius: 0;
  224. background-size: 0 2px,100% 1px;
  225. background-repeat: no-repeat;
  226. background-position: center bottom,center calc(100% - 1px);
  227. background-color: transparent;
  228. box-shadow: none;
  229. }.gn-menu li.active i.fa {
  230. color: <?=$activetabicon;?>;
  231. }.gn-menu li i.fa {
  232. color: <?=$inactiveicon;?>;
  233. }.gn-menu-main ul.gn-menu a {
  234. color: <?=$inactivetext;?>;
  235. }li.dropdown.some-btn .mdi {
  236. color: <?=$topbartext;?>;
  237. }.nav>li>a:focus, .nav>li>a:hover {
  238. text-decoration: none;
  239. background-color: transparent;
  240. }div#preloader {
  241. background-color: <?=$topbartext;?>;
  242. }.iframe {
  243. -webkit-overflow-scrolling: touch;
  244. }.iframe iframe{
  245. }#menu-toggle span {
  246. background: <?=$topbartext;?>;
  247. }logo.logo {
  248. opacity: 0.5;
  249. filter: alpha(opacity=50);
  250. }
  251. </style>
  252. <ul id="gn-menu" class="gn-menu-main">
  253. <li class="gn-trigger">
  254. <a id="menu-toggle" class="menu-toggle gn-icon gn-icon-menu">
  255. <div class="hamburger">
  256. <span></span>
  257. <span></span>
  258. <span></span>
  259. </div>
  260. <div class="cross">
  261. <span></span>
  262. <span></span>
  263. </div>
  264. </a>
  265. <nav class="gn-menu-wrapper">
  266. <div class="gn-scroller" id="gn-scroller">
  267. <ul class="gn-menu metismenu">
  268. <!--Start Tab List-->
  269. <?php if($tabSetup == "No") : foreach($result as $row) :
  270. if($row['defaultz'] == "true") : $defaultz = "active"; else : $defaultz = ""; endif;?>
  271. <li window="<?=$row['window'];?>" class="tab-item <?=$defaultz;?>" id="<?=$row['url'];?>x" name="<?php echo strtolower($row['name']);?>">
  272. <a class="tab-link">
  273. <?php if($row['iconurl']) : ?>
  274. <i style="font-size: 19px; padding: 0 10px; font-size: 19px;">
  275. <img src="<?=$row['iconurl'];?>" style="height: 30px; margin-top: -2px;">
  276. </i>
  277. <?php else : ?>
  278. <i class="fa <?=$row['icon'];?> fa-lg"></i>
  279. <?php endif; ?>
  280. <?=$row['name'];?>
  281. </a>
  282. </li>
  283. <?php endforeach; endif;?>
  284. <?php if($configReady == "Yes") : if($USER->authenticated && $USER->role == "admin") :?>
  285. <li class="tab-item <?=$settingsActive;?>" id="settings.phpx">
  286. <a class="tab-link">
  287. <?php if($settingsicon == "Yes") :
  288. echo '<i style="font-size: 19px; padding: 0 10px; font-size: 19px;">
  289. <img id="settings-icon" src="images/settings.png" style="height: 30px; margin-top: -2px;"></i>';
  290. else :
  291. echo '<i id="settings-icon" class="fa fa-cog"></i>';
  292. endif; ?>
  293. Settings
  294. </a>
  295. </li>
  296. <?php endif; endif;?>
  297. <!--End Tab List-->
  298. </ul>
  299. </div>
  300. <!-- /gn-scroller -->
  301. <div class="bottom-bnts">
  302. <a class="fix-nav"><i class="mdi mdi-pin"></i></a>
  303. </div>
  304. </nav>
  305. </li>
  306. <li class="top-clock">
  307. <span><span style="color:<?=$topbartext;?>;"><b><?=$title;?></b></span></span>
  308. </li>
  309. <li class="pull-right">
  310. <ul class="nav navbar-right right-menu">
  311. <li class="dropdown notifications">
  312. <?php if($configReady == "Yes") : if(!$USER->authenticated) : ?>
  313. <a class="log-in">
  314. <?php endif; endif;?>
  315. <?php if($configReady == "Yes") : if($USER->authenticated) : ?>
  316. <a class="show-members">
  317. <?php endif; endif;?>
  318. <i class="userpic"><img src="https://www.gravatar.com/avatar/<?=$userpic;?>?s=40&d=mm" class="img-circle"></i>
  319. </a>
  320. </li>
  321. <li class="dropdown some-btn">
  322. <a class="fullscreen">
  323. <i class="mdi mdi-fullscreen"></i>
  324. </a>
  325. </li>
  326. <li class="dropdown some-btn">
  327. <a id="reload" class="refresh">
  328. <i class="mdi mdi-refresh"></i>
  329. </a>
  330. </li>
  331. </ul>
  332. </li>
  333. </ul>
  334. <!--Content-->
  335. <div id="content" class="content" style="">
  336. <script>addToHomescreen();</script>
  337. <!--Load Framed Content-->
  338. <?php if($needSetup == "Yes" && $configReady == "Yes") : ?>
  339. <div class="table-wrapper">
  340. <div class="table-row">
  341. <div class="table-cell text-center">
  342. <div class="login i-block">
  343. <div class="content-box">
  344. <div class="green-bg biggest-box">
  345. <h1 class="zero-m text-uppercase">Create Admin</h1>
  346. </div>
  347. <div class="big-box text-left registration-form">
  348. <h4 class="text-center">Create an account for Admin Access</h4>
  349. <form class="controlbox" name="new user registration" id="registration" action="" method="POST" data-smk-icon="glyphicon-remove-sign">
  350. <input type="hidden" name="op" value="register"/>
  351. <input type="hidden" name="sha1" value=""/>
  352. <div class="form-group">
  353. <input type="text" class="form-control material" name="username" autofocus placeholder="Username" autocorrect="off" autocapitalize="off" minlength="3" maxlength="16" required>
  354. </div>
  355. <div class="form-group">
  356. <input type="email" class="form-control material" name="email" placeholder="E-mail">
  357. </div>
  358. <div class="form-group">
  359. <input type="password" class="form-control material" name="password1" placeholder="Password" data-smk-strongPass="weak" required>
  360. </div>
  361. <div class="form-group">
  362. <input type="password" class="form-control material" name="password2" placeholder="Retype Password">
  363. </div>
  364. <button id="registerSubmit" type="submit" class="btn green-bg btn-block btn-warning text-uppercase waves waves-effect waves-float" value="Register">Register</button>
  365. </form>
  366. </div>
  367. </div>
  368. </div>
  369. </div>
  370. </div>
  371. </div>
  372. <?php endif; ?>
  373. <?php if($needSetup == "Yes" && $configReady == "No") : ?>
  374. <div class="table-wrapper">
  375. <div class="table-row">
  376. <div class="table-cell text-center">
  377. <div class="login i-block">
  378. <div class="content-box">
  379. <div class="green-bg biggest-box">
  380. <h1 class="zero-m text-uppercase">Database Path</h1>
  381. </div>
  382. <div class="big-box text-left registration-form">
  383. <h3 class="text-center">Specify the location of which you want to save your database files.</h3>
  384. <h5 class="text-left"><strong>Current Directory: <?php echo __DIR__; ?> <br>Parent Directory: <?php echo dirname(__DIR__); ?></strong></h5>
  385. <form class="controlbox" name="setupDatabase" id="setupDatabase" action="" method="POST" data-smk-icon="glyphicon-remove-sign">
  386. <input type="hidden" name="action" value="createLocation" />
  387. <div class="form-group">
  388. <input type="text" class="form-control material" name="databaseLocation" autofocus value="<?php echo dirname(__DIR__);?>" autocorrect="off" autocapitalize="off" required>
  389. <?php if(file_exists(dirname(__DIR__) . '/users.db') || file_exists(__DIR__ . '/users.db')) : echo '<h5 class="text-center red">Don\'t worry, you\'re database is still there. Just use the same location you have it in.</h5>'; endif;?>
  390. </div>
  391. <button id="databaseLocationSubmit" type="submit" class="btn green-bg btn-block btn-sm text-uppercase waves waves-effect waves-float" value="Save Location">Save Location</button>
  392. </form>
  393. </div>
  394. </div>
  395. </div>
  396. </div>
  397. </div>
  398. </div>
  399. <?php endif; ?>
  400. <?php if($configReady == "Yes") : if(!$USER->authenticated && $tabSetup == "Yes" && $needSetup == "No") :?>
  401. <div class="table-wrapper">
  402. <div class="table-row">
  403. <div class="table-cell text-center">
  404. <div class="login i-block">
  405. <div class="content-box">
  406. <div class="blue-bg biggest-box">
  407. <h1 class="zero-m text-uppercase">Awesome!</h1>
  408. </div>
  409. <div class="big-box text-left registration-form">
  410. <h4 class="text-center">Now that you created an Admin account, time to sign and start making some tabs...</h4>
  411. <button type="submit" class="btn log-in btn-block btn-primary text-uppercase waves waves-effect waves-float">Login</button>
  412. </div>
  413. </div>
  414. </div>
  415. </div>
  416. </div>
  417. </div>
  418. <?php endif; endif; ?>
  419. <?php if($tabSetup == "No" && $needSetup == "No") :?>
  420. <div id="tabEmpty" class="table-wrapper" style="display: none">
  421. <div class="table-row">
  422. <div class="table-cell text-center">
  423. <div class="login i-block">
  424. <div class="content-box">
  425. <div class="red-bg biggest-box">
  426. <h1 class="zero-m text-uppercase">Hold Up!</h1>
  427. </div>
  428. <div class="big-box text-left registration-form">
  429. <br><br><br>
  430. <h2 class="text-center">Looks like you don't have access.</h2>
  431. <?php if(!$USER->authenticated) : ?>
  432. <button style="background:<?=$topbar;?>;" type="submit" class="btn log-in btn-block btn-primary text-uppercase waves waves-effect waves-float"><text style="color:<?=$topbartext;?>;">Login</text></button>
  433. <?php endif; ?>
  434. </div>
  435. </div>
  436. </div>
  437. </div>
  438. </div>
  439. </div>
  440. <?php endif;?>
  441. <!--End Load Framed Content-->
  442. </div>
  443. <!--End Content-->
  444. <!--Welcome notification-->
  445. <div id="welcome"></div>
  446. <div id="members-sidebar" style="background: <?=$sidebar;?>;" class="members-sidebar">
  447. <h4 class="pull-left zero-m">Options</h4>
  448. <span class="close-members-sidebar"><i class="fa fa-remove fa-lg pull-right"></i></span>
  449. <div class="clearfix"><br/></div>
  450. <?php if($configReady == "Yes") : if($USER->authenticated) : ?>
  451. <br>
  452. <div class="content-box profile-sidebar box-shadow">
  453. <img src="https://www.gravatar.com/avatar/<?=$userpic;?>?s=100&d=mm" class="img-responsive img-circle center-block" alt="user" https:="" www.gravatar.com="" avatar="">
  454. <div class="profile-usertitle">
  455. <div class="profile-usertitle-name">
  456. <?php echo strtoupper($USER->username); ?>
  457. </div>
  458. <div class="profile-usertitle-job">
  459. <?php echo strtoupper($USER->role); ?>
  460. </div>
  461. </div>
  462. <div id="buttonsDiv" class="profile-userbuttons">
  463. <button id="editInfo" type="button" class="btn btn-primary text-uppercase waves waves-effect waves-float">Edit Info</button>
  464. <button type="button" class="logout btn btn-warning waves waves-effect waves-float">Logout</button>
  465. </div>
  466. <div id="editInfoDiv" style="display: none" class="profile-usertitle">
  467. <form class="content-form form-inline" name="update" id="update" action="" method="POST">
  468. <input type="hidden" name="op" value="update"/>
  469. <input type="hidden" name="sha1" value=""/>
  470. <input type="hidden" name="role" value="<?php echo $USER->role; ?>"/>
  471. <div class="form-group">
  472. <input autocomplete="off" type="text" value="<?php echo $USER->email; ?>" class="form-control" name="email" placeholder="E-mail Address">
  473. </div>
  474. <div class="form-group">
  475. <input autocomplete="off" type="password" class="form-control" name="password1" placeholder="Password">
  476. </div>
  477. <div class="form-group">
  478. <input autocomplete="off" type="password" class="form-control" name="password2" placeholder="Password Again">
  479. </div>
  480. <br>
  481. <div class="form-group">
  482. <input type="button" class="btn btn-success text-uppercase waves-effect waves-float" value="Update" onclick="User.processUpdate()"/>
  483. <button id="goBackButtons" type="button" class="btn btn-primary text-uppercase waves waves-effect waves-float">Go Back</button>
  484. </div>
  485. </form>
  486. </div>
  487. </div>
  488. <?php endif; endif;?>
  489. </div>
  490. </div>
  491. <?php if($configReady == "Yes") : if(!$USER->authenticated && $configReady == "Yes") : ?>
  492. <div class="login-modal modal fade">
  493. <div style="background:<?=$sidebar;?>;" class="table-wrapper">
  494. <div class="table-row">
  495. <div class="table-cell text-center">
  496. <button style="color:<?=$topbartext;?>;" type="button" class="close" data-dismiss="modal" aria-label="Close">
  497. <span aria-hidden="true">&times;</span>
  498. </button>
  499. <div class="login i-block">
  500. <div class="content-box">
  501. <div style="background:<?=$topbar;?>;" class="biggest-box">
  502. <h1 style="color:<?=$topbartext;?>;" class="zero-m text-uppercase">Welcome</h1>
  503. </div>
  504. <div class="big-box text-left login-form">
  505. <?php if($USER->error!="") : ?>
  506. <p class="error">Error: <?php echo $USER->error; ?></p>
  507. <?php endif; ?>
  508. <form name="log in" id="login" action="" method="POST" data-smk-icon="glyphicon-remove-sign">
  509. <h4 class="text-center">Login</h4>
  510. <div class="form-group">
  511. <input type="hidden" name="op" value="login">
  512. <input type="hidden" name="sha1" value="">
  513. <input type="hidden" name="rememberMe" value="false"/>
  514. <input type="text" class="form-control material" name="username" placeholder="Username" autocorrect="off" autocapitalize="off" value="" autofocus required>
  515. </div>
  516. <div class="form-group">
  517. <input type="password" class="form-control material" name="password1" placeholder="Password" required>
  518. </div>
  519. <div class="form-group">
  520. <div class="i-block"> <input id="rememberMe" name="rememberMe" class="switcher switcher-success switcher-medium pull-left" value="true" type="checkbox" checked="">
  521. <label for="rememberMe" class="pull-left"></label>
  522. <label class="pull-right"> &nbsp; Remember Me</label>
  523. </div>
  524. </div>
  525. <button id="loginSubmit" style="background:<?=$topbar;?>;" type="submit" class="btn btn-block btn-info text-uppercase waves" value="log in" onclick="User.processLogin()"><text style="color:<?=$topbartext;?>;">Login</text></button>
  526. </form>
  527. <button id="switchForgot" class="btn btn-block btn-info text-uppercase waves">Forgot Password</button>
  528. <form style="display: none;" name="forgotPassword" id="forgotPassword" action="" method="POST" data-smk-icon="glyphicon-remove-sign">
  529. <h4 class="text-center">Forgot Password</h4>
  530. <div class="form-group">
  531. <input type="hidden" name="op" value="reset">
  532. <input type="text" class="form-control material" name="email" placeholder="E-mail" autocorrect="off" autocapitalize="off" value="" autofocus required>
  533. </div>
  534. <button style="background:<?=$topbar;?>;" type="submit" class="btn btn-block btn-info text-uppercase waves" value="reset password"><text style="color:<?=$topbartext;?>;">Reset Password</text></button>
  535. </form>
  536. </div>
  537. </div>
  538. </div>
  539. </div>
  540. </div>
  541. </div>
  542. </div>
  543. <?php endif; endif;?>
  544. <?php if($configReady == "Yes") : if($USER->authenticated) : ?>
  545. <div style="background:<?=$topbar;?>;" class="logout-modal modal fade">
  546. <div class="table-wrapper" style="background: <?=$topbar;?>">
  547. <div class="table-row">
  548. <div class="table-cell text-center">
  549. <div class="login i-block">
  550. <div class="content-box">
  551. <div style="background:<?=$topbartext;?>;" class="biggest-box">
  552. <form name="log out" id="logout" action="" method="POST">
  553. <input type="hidden" name="op" value="logout">
  554. <input type="hidden" name="username"value="<?php echo $_SESSION["username"]; ?>" >
  555. <h3 style="color:<?=$topbar;?>;" class="zero-m text-uppercase">Do you want to logout?</h3>
  556. <a style="color:<?=$topbar;?>;" id="logoutSubmit" class="i-block" data-dismiss="modal">Yes</a>
  557. <a style="color:<?=$topbar;?>;" class="i-block" data-dismiss="modal">No</a>
  558. </form>
  559. </div>
  560. </div>
  561. </div>
  562. </div>
  563. </div>
  564. </div>
  565. </div>
  566. <?php endif; endif;?>
  567. <!--Scripts-->
  568. <script src="<?=$baseURL;?>bower_components/jquery/dist/jquery.min.js"></script>
  569. <script src="<?=$baseURL;?>bower_components/bootstrap/dist/js/bootstrap.min.js"></script>
  570. <script src="<?=$baseURL;?>bower_components/metisMenu/dist/metisMenu.min.js"></script>
  571. <script src="<?=$baseURL;?>bower_components/Waves/dist/waves.min.js"></script>
  572. <script src="<?=$baseURL;?>bower_components/moment/min/moment.min.js"></script>
  573. <script src="<?=$baseURL;?>bower_components/jquery.nicescroll/jquery.nicescroll.min.js"></script>
  574. <script src="<?=$baseURL;?>bower_components/slimScroll/jquery.slimscroll.min.js"></script>
  575. <script src="<?=$baseURL;?>bower_components/malihu-custom-scrollbar-plugin/jquery.mCustomScrollbar.js"></script>
  576. <script src="<?=$baseURL;?>bower_components/cta/dist/cta.min.js"></script>
  577. <!--Menu-->
  578. <script src="<?=$baseURL;?>js/menu/classie.js"></script>
  579. <script src="<?=$baseURL;?>js/menu/gnmenu.js"></script>
  580. <!--Selects-->
  581. <script src="<?=$baseURL;?>js/selects/selectFx.js"></script>
  582. <script src="<?=$baseURL;?>bower_components/sweetalert/dist/sweetalert.min.js"></script>
  583. <script src="<?=$baseURL;?>bower_components/smoke/dist/js/smoke.min.js"></script>
  584. <!--Notification-->
  585. <script src="<?=$baseURL;?>js/notifications/notificationFx.js"></script>
  586. <!--Custom Scripts-->
  587. <script src="<?=$baseURL;?>js/common.js"></script>
  588. <script>
  589. var fixed = document.getElementById('gn-scroller');
  590. fixed.addEventListener('touchmove', function(e) {
  591. e.preventDefault();
  592. }, false);
  593. function setHeight() {
  594. windowHeight = $(window).innerHeight();
  595. $("div").find(".iframe").css('height', windowHeight - 56 + "px");
  596. $('#content').css('height', windowHeight - 56 + "px");
  597. };
  598. $('#loginSubmit').click(function() {
  599. if ($('#login').smkValidate()) {
  600. console.log("validated");
  601. }
  602. console.log("didnt validate");
  603. });
  604. $('#registerSubmit').click(function() {
  605. if ($('#registration').smkValidate()) {
  606. console.log("validated");
  607. }
  608. console.log("didnt validate");
  609. User.processRegistration();
  610. });
  611. $("#editInfo").click(function(){
  612. $( "div[id^='editInfoDiv']" ).toggle();
  613. $( "div[id^='buttonsDiv']" ).toggle();
  614. });
  615. $("#goBackButtons").click(function(){
  616. $( "div[id^='editInfoDiv']" ).toggle();
  617. $( "div[id^='buttonsDiv']" ).toggle();
  618. });
  619. $("#switchForgot").click(function(){
  620. $( "form[id^='login']" ).toggle();
  621. $( "form[id^='forgotPassword']" ).toggle();
  622. $("#switchForgot").toggle();
  623. });
  624. //Sign in
  625. $(".log-in").click(function(e){
  626. var e1 = document.querySelector(".log-in"),
  627. e2 = document.querySelector(".login-modal");
  628. cta(e1, e2, {relativeToWindow: true}, function () {
  629. $('.login-modal').modal("show");
  630. });
  631. e.preventDefault();
  632. });
  633. //Logout
  634. $(".logout").click(function(e){
  635. var el1 = document.querySelector(".logout"),
  636. el2 = document.querySelector(".logout-modal");
  637. cta(el1, el2, {relativeToWindow: true}, function () {
  638. $('.logout-modal').modal("show");
  639. });
  640. e.preventDefault();
  641. });
  642. //Members Sidebar
  643. $(".show-members").click(function(e){
  644. var e_s1 = document.querySelector(".show-members"),
  645. e_s2 = document.querySelector("#members-sidebar");
  646. cta(e_s1, e_s2, {relativeToWindow: true}, function () {
  647. $('#members-sidebar').addClass('members-sidebar-open');
  648. });
  649. e.preventDefault();
  650. });
  651. $('.close-members-sidebar').click(function(){
  652. $('#members-sidebar').removeClass('members-sidebar-open');
  653. });
  654. $(document).ready(function(){
  655. defaultTab = $("li[class^='tab-item active']").attr("id");
  656. if (defaultTab){
  657. defaultTab = defaultTab.substr(0, defaultTab.length-1);
  658. }else{
  659. defaultTabNone = $("li[class^='tab-item']").attr("id");
  660. if (defaultTabNone){
  661. $("li[class^='tab-item']").first().attr("class", "tab-item active");
  662. defaultTab = defaultTabNone.substr(0, defaultTabNone.length-1);
  663. }
  664. }
  665. if (defaultTab){
  666. $("#content").html('<div class="iframe active" data-content-url="'+defaultTab+'"><iframe scrolling="auto" sandbox="allow-forms allow-same-origin allow-pointer-lock allow-scripts allow-popups allow-modals" allowfullscreen="true" webkitallowfullscreen="true" frameborder="0" style="width:100%; height:100%;" src="'+defaultTab+'"></iframe></div>');
  667. }
  668. if (defaultTab == null){
  669. $("div[id^='tabEmpty']").show();
  670. }
  671. if ($(location).attr('hash')){
  672. var getHash = $(location).attr('hash').substr(1).replace("%20", " ").replace("_", " ");
  673. var gotHash = getHash.toLowerCase();
  674. var getLiTab = $("li[name^='" + gotHash + "']");
  675. getLiTab.trigger("click");
  676. }
  677. setHeight();
  678. });
  679. $(function () {
  680. <?php if(!empty($USER->info_log)) : ?>
  681. $.smkAlert({
  682. position: 'top-left',
  683. text: '<?php echo printArray($USER->info_log);?>',
  684. type: 'info'
  685. });
  686. <?php endif; ?>
  687. <?php if(!empty($USER->error_log)) : ?>
  688. $.smkAlert({
  689. position: 'top-left',
  690. text: '<?php echo printArray($USER->error_log); ?>',
  691. type: 'warning'
  692. });
  693. <?php endif; ?>
  694. });
  695. $('#reload').on('click tap', function(){
  696. $("i[class^='mdi mdi-refresh']").attr("class", "mdi mdi-refresh fa-spin");
  697. var activeFrame = $('#content').find('.active').children('iframe');
  698. activeFrame.attr('src', activeFrame.attr('src'));
  699. var refreshBox = $('#content').find('.active');
  700. $("<div class='refresh-preloader'><div class='la-timer la-dark'><div></div></div></div>").appendTo(refreshBox).fadeIn(10);
  701. setTimeout(function(){
  702. var refreshPreloader = refreshBox.find('.refresh-preloader'),
  703. deletedRefreshBox = refreshPreloader.fadeOut(300, function(){
  704. refreshPreloader.remove();
  705. $("i[class^='mdi mdi-refresh fa-spin']").attr("class", "mdi mdi-refresh");
  706. });
  707. },500);
  708. });
  709. $("li[id^='settings.phpx']").on('click tap', function(){
  710. $("img[id^='settings-icon']").attr("class", "fa-spin");
  711. $("i[id^='settings-icon']").attr("class", "fa fa-cog fa-spin");
  712. setTimeout(function(){
  713. $("img[id^='settings-icon']").attr("class", "");
  714. $("i[id^='settings-icon']").attr("class", "fa fa-cog");
  715. },1000);
  716. });
  717. $('#logoutSubmit').on('click tap', function(){
  718. $( "#logout" ).submit();
  719. });
  720. $(window).resize(function(){
  721. setHeight();
  722. });
  723. $("li[class^='tab-item']").on('click vclick', function(){
  724. var thisidfull = $(this).attr("id");
  725. var thisid = thisidfull.substr(0, thisidfull.length-1);
  726. var currentframe = $("div[data-content-url^='"+thisid+"']");
  727. if (currentframe.attr("class") == "iframe active") {
  728. console.log(thisid + " is active already");
  729. }else if (currentframe.attr("class") == "iframe hidden") {
  730. console.log(thisid + " is active already but hidden");
  731. $("div[class^='iframe active']").attr("class", "iframe hidden");
  732. currentframe.attr("class", "iframe active");
  733. setHeight();
  734. $("li[class^='tab-item active']").attr("class", "tab-item");
  735. $(this).attr("class", "tab-item active");
  736. }else {
  737. if ($(this).attr("window") == "true") {
  738. window.open(thisid,'_blank');
  739. }else {
  740. console.log(thisid + " make new div");
  741. $("div[class^='iframe active']").attr("class", "iframe hidden");
  742. $( '<div class="iframe active" data-content-url="'+thisid+'"><iframe scrolling="auto" sandbox="allow-forms allow-same-origin allow-pointer-lock allow-scripts allow-popups allow-modals" allowfullscreen="true" webkitallowfullscreen="true" frameborder="0" style="width:100%; height:100%;" src="'+thisid+'"></iframe></div>' ).appendTo( "#content" );
  743. setHeight();
  744. $("li[class^='tab-item active']").attr("class", "tab-item");
  745. $(this).attr("class", "tab-item active");
  746. }
  747. }
  748. });
  749. </script>
  750. </body>
  751. </html>