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