index.php 50 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323
  1. <?php
  2. //Set some variables
  3. ini_set("display_errors", 1);
  4. ini_set("error_reporting", E_ALL | E_STRICT);
  5. $data = false;
  6. $databaseLocation = "databaseLocation.ini.php";
  7. $needSetup = "Yes";
  8. $tabSetup = "Yes";
  9. $hasOptions = "No";
  10. $settingsicon = "No";
  11. $settingsActive = "";
  12. $action = "";
  13. $title = "Organizr";
  14. $topbar = "#eb6363";
  15. $topbartext = "#FFFFFF";
  16. $bottombar = "#eb6363";
  17. $sidebar = "#000000";
  18. $hoverbg = "#eb6363";
  19. $activetabBG = "#eb6363";
  20. $activetabicon = "#FFFFFF";
  21. $activetabtext = "#FFFFFF";
  22. $inactiveicon = "#FFFFFF";
  23. $inactivetext = "#FFFFFF";
  24. $baseURL = "";
  25. function registration_callback($username, $email, $userdir){
  26. global $data;
  27. $data = array($username, $email, $userdir);
  28. }
  29. function printArray($arrayName){
  30. foreach ( $arrayName as $item ) :
  31. echo $item . "<br/>";
  32. endforeach;
  33. }
  34. function write_ini_file($content, $path) {
  35. if (!$handle = fopen($path, 'w')) {
  36. return false;
  37. }
  38. $success = fwrite($handle, $content);
  39. fclose($handle);
  40. return $success;
  41. }
  42. if(isset($_POST['action'])) :
  43. $action = $_POST['action'];
  44. endif;
  45. if($action == "createLocation") :
  46. $databaseData = '; <?php die("Access denied"); ?>' . "\r\n";
  47. foreach ($_POST as $postName => $postValue) {
  48. if($postName !== "action") :
  49. if(substr($postValue, -1) == "/") : $postValue = rtrim($postValue, "/"); endif;
  50. $databaseData .= $postName . " = \"" . $postValue . "\"\r\n";
  51. endif;
  52. }
  53. write_ini_file($databaseData, $databaseLocation);
  54. endif;
  55. if(!file_exists($databaseLocation)) :
  56. $configReady = "No";
  57. $userpic = "";
  58. else :
  59. $configReady = "Yes";
  60. require_once("user.php");
  61. $USER = new User("registration_callback");
  62. date_default_timezone_set(TIMEZONE);
  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">
  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. <h5>Set Database Location</h5>
  391. <input type="text" class="form-control material" name="timezone" autofocus value="<?php echo date_default_timezone_get();?>" autocorrect="off" autocapitalize="off" required>
  392. <h5>Set Timezone</h5>
  393. <?php if(file_exists(dirname(__DIR__) . '/users.db') || file_exists(__DIR__ . '/users.db')) : echo '<h5 class="text-center red">Don\'t worry, your database is still there. Just use the same location you have it in.</h5>'; endif;?>
  394. </div>
  395. <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>
  396. </form>
  397. </div>
  398. </div>
  399. </div>
  400. </div>
  401. </div>
  402. </div>
  403. <?php endif; ?>
  404. <?php if($configReady == "Yes") : if(!$USER->authenticated && $tabSetup == "Yes" && $needSetup == "No") :?>
  405. <div class="table-wrapper">
  406. <div class="table-row">
  407. <div class="table-cell text-center">
  408. <div class="login i-block">
  409. <div class="content-box">
  410. <div class="blue-bg biggest-box">
  411. <h1 class="zero-m text-uppercase">Awesome!</h1>
  412. </div>
  413. <div class="big-box text-left registration-form">
  414. <h4 class="text-center">Now that you created an Admin account, time to sign and start making some tabs...</h4>
  415. <button type="submit" class="btn log-in btn-block btn-primary text-uppercase waves waves-effect waves-float">Login</button>
  416. </div>
  417. </div>
  418. </div>
  419. </div>
  420. </div>
  421. </div>
  422. <?php endif; endif; ?>
  423. <?php if($tabSetup == "No" && $needSetup == "No") :?>
  424. <div id="tabEmpty" class="table-wrapper" style="display: none; background:<?=$sidebar;?>;">
  425. <div class="table-row">
  426. <div class="table-cell text-center">
  427. <div class="login i-block">
  428. <div class="content-box">
  429. <div class="biggest-box" style="background:<?=$topbar;?>;">
  430. <h1 class="zero-m text-uppercase" style="color:<?=$topbartext;?>;">Hold Up!</h1>
  431. </div>
  432. <div class="big-box text-left">
  433. <center><img src="images/sowwy.png" style="height: 200px;"></center>
  434. <h2 class="text-center">Looks like you don't have access.</h2>
  435. <?php if(!$USER->authenticated) : ?>
  436. <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>
  437. <?php endif; ?>
  438. </div>
  439. </div>
  440. </div>
  441. </div>
  442. </div>
  443. </div>
  444. <?php endif;?>
  445. <!--End Load Framed Content-->
  446. </div>
  447. <!--End Content-->
  448. <!--Welcome notification-->
  449. <div id="welcome"></div>
  450. <div id="members-sidebar" style="background: <?=$sidebar;?>;" class="members-sidebar">
  451. <h4 class="pull-left zero-m">Options</h4>
  452. <span class="close-members-sidebar"><i class="fa fa-remove fa-lg pull-right"></i></span>
  453. <div class="clearfix"><br/></div>
  454. <?php if($configReady == "Yes") : if($USER->authenticated) : ?>
  455. <br>
  456. <div class="content-box profile-sidebar box-shadow">
  457. <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="">
  458. <div class="profile-usertitle">
  459. <div class="profile-usertitle-name">
  460. <?php echo strtoupper($USER->username); ?>
  461. </div>
  462. <div class="profile-usertitle-job">
  463. <?php echo strtoupper($USER->role); ?>
  464. </div>
  465. </div>
  466. <div id="buttonsDiv" class="profile-userbuttons">
  467. <button id="editInfo" type="button" class="btn btn-primary text-uppercase waves waves-effect waves-float">Edit Info</button>
  468. <button type="button" class="logout btn btn-warning waves waves-effect waves-float">Logout</button>
  469. </div>
  470. <div id="editInfoDiv" style="display: none" class="profile-usertitle">
  471. <form class="content-form form-inline" name="update" id="update" action="" method="POST">
  472. <input type="hidden" name="op" value="update"/>
  473. <input type="hidden" name="sha1" value=""/>
  474. <input type="hidden" name="role" value="<?php echo $USER->role; ?>"/>
  475. <div class="form-group">
  476. <input autocomplete="off" type="text" value="<?php echo $USER->email; ?>" class="form-control" name="email" placeholder="E-mail Address">
  477. </div>
  478. <div class="form-group">
  479. <input autocomplete="off" type="password" class="form-control" name="password1" placeholder="Password">
  480. </div>
  481. <div class="form-group">
  482. <input autocomplete="off" type="password" class="form-control" name="password2" placeholder="Password Again">
  483. </div>
  484. <br>
  485. <div class="form-group">
  486. <input type="button" class="btn btn-success text-uppercase waves-effect waves-float" value="Update" onclick="User.processUpdate()"/>
  487. <button id="goBackButtons" type="button" class="btn btn-primary text-uppercase waves waves-effect waves-float">Go Back</button>
  488. </div>
  489. </form>
  490. </div>
  491. </div>
  492. <?php endif; endif;?>
  493. </div>
  494. </div>
  495. <?php if($configReady == "Yes") : if(!$USER->authenticated && $configReady == "Yes") : ?>
  496. <div class="login-modal modal fade">
  497. <div style="background:<?=$sidebar;?>;" class="table-wrapper">
  498. <div class="table-row">
  499. <div class="table-cell text-center">
  500. <button style="color:<?=$topbartext;?>;" type="button" class="close" data-dismiss="modal" aria-label="Close">
  501. <span aria-hidden="true">&times;</span>
  502. </button>
  503. <div class="login i-block">
  504. <div class="content-box">
  505. <div style="background:<?=$topbar;?>;" class="biggest-box">
  506. <h1 style="color:<?=$topbartext;?>;" class="zero-m text-uppercase">Welcome</h1>
  507. </div>
  508. <div class="big-box text-left login-form">
  509. <?php if($USER->error!="") : ?>
  510. <p class="error">Error: <?php echo $USER->error; ?></p>
  511. <?php endif; ?>
  512. <form name="log in" id="login" action="" method="POST" data-smk-icon="glyphicon-remove-sign">
  513. <h4 class="text-center">Login</h4>
  514. <div class="form-group">
  515. <input type="hidden" name="op" value="login">
  516. <input type="hidden" name="sha1" value="">
  517. <input type="hidden" name="rememberMe" value="false"/>
  518. <input type="text" class="form-control material" name="username" placeholder="Username" autocomplete="off" autocorrect="off" autocapitalize="off" value="" autofocus required>
  519. </div>
  520. <div class="form-group">
  521. <input type="password" class="form-control material" name="password1" value="" autocomplete="off" placeholder="Password" required>
  522. </div>
  523. <div class="form-group">
  524. <div class="i-block"> <input id="rememberMe" name="rememberMe" class="switcher switcher-success switcher-medium pull-left" value="true" type="checkbox" checked="">
  525. <label for="rememberMe" class="pull-left"></label>
  526. <label class="pull-right"> &nbsp; Remember Me</label>
  527. </div>
  528. </div>
  529. <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>
  530. </form>
  531. <button id="switchForgot" style="background:<?=$topbartext;?>;" class="btn btn-block btn-info text-uppercase waves"><text style="color:<?=$topbar;?>;">Forgot Password</text></button>
  532. <form style="display: none;" name="forgotPassword" id="forgotPassword" action="" method="POST" data-smk-icon="glyphicon-remove-sign">
  533. <h4 class="text-center">Forgot Password</h4>
  534. <div class="form-group">
  535. <input type="hidden" name="op" value="reset">
  536. <input type="text" class="form-control material" name="email" placeholder="E-mail" autocorrect="off" autocapitalize="off" value="" autofocus required>
  537. </div>
  538. <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>
  539. </form>
  540. </div>
  541. </div>
  542. </div>
  543. </div>
  544. </div>
  545. </div>
  546. </div>
  547. <?php endif; endif;?>
  548. <?php if($configReady == "Yes") : if($USER->authenticated) : ?>
  549. <div style="background:<?=$topbar;?>;" class="logout-modal modal fade">
  550. <div class="table-wrapper" style="background: <?=$topbar;?>">
  551. <div class="table-row">
  552. <div class="table-cell text-center">
  553. <div class="login i-block">
  554. <div class="content-box">
  555. <div style="background:<?=$topbartext;?>;" class="biggest-box">
  556. <form name="log out" id="logout" action="" method="POST">
  557. <input type="hidden" name="op" value="logout">
  558. <input type="hidden" name="username"value="<?php echo $_SESSION["username"]; ?>" >
  559. <h3 style="color:<?=$topbar;?>;" class="zero-m text-uppercase">Do you want to logout?</h3>
  560. <a style="color:<?=$topbar;?>;" id="logoutSubmit" class="i-block" data-dismiss="modal">Yes</a>
  561. <a style="color:<?=$topbar;?>;" class="i-block" data-dismiss="modal">No</a>
  562. </form>
  563. </div>
  564. </div>
  565. </div>
  566. </div>
  567. </div>
  568. </div>
  569. </div>
  570. <?php endif; endif;?>
  571. <!--Scripts-->
  572. <script src="<?=$baseURL;?>bower_components/jquery/dist/jquery.min.js"></script>
  573. <script src="<?=$baseURL;?>bower_components/bootstrap/dist/js/bootstrap.min.js"></script>
  574. <script src="<?=$baseURL;?>bower_components/metisMenu/dist/metisMenu.min.js"></script>
  575. <script src="<?=$baseURL;?>bower_components/Waves/dist/waves.min.js"></script>
  576. <script src="<?=$baseURL;?>bower_components/moment/min/moment.min.js"></script>
  577. <script src="<?=$baseURL;?>bower_components/jquery.nicescroll/jquery.nicescroll.min.js"></script>
  578. <script src="<?=$baseURL;?>bower_components/slimScroll/jquery.slimscroll.min.js"></script>
  579. <script src="<?=$baseURL;?>bower_components/malihu-custom-scrollbar-plugin/jquery.mCustomScrollbar.js"></script>
  580. <script src="<?=$baseURL;?>bower_components/cta/dist/cta.min.js"></script>
  581. <!--Menu-->
  582. <script src="<?=$baseURL;?>js/menu/classie.js"></script>
  583. <script src="<?=$baseURL;?>js/menu/gnmenu.js"></script>
  584. <!--Selects-->
  585. <script src="<?=$baseURL;?>js/selects/selectFx.js"></script>
  586. <script src="<?=$baseURL;?>bower_components/sweetalert/dist/sweetalert.min.js"></script>
  587. <script src="<?=$baseURL;?>bower_components/smoke/dist/js/smoke.min.js"></script>
  588. <!--Notification-->
  589. <script src="<?=$baseURL;?>js/notifications/notificationFx.js"></script>
  590. <!--Custom Scripts-->
  591. <script src="<?=$baseURL;?>js/common.js"></script>
  592. <script>
  593. var fixed = document.getElementById('gn-scroller');
  594. fixed.addEventListener('touchmove', function(e) {
  595. e.preventDefault();
  596. }, false);
  597. function setHeight() {
  598. windowHeight = $(window).innerHeight();
  599. $("div").find(".iframe").css('height', windowHeight - 56 + "px");
  600. $('#content').css('height', windowHeight - 56 + "px");
  601. };
  602. $('#loginSubmit').click(function() {
  603. if ($('#login').smkValidate()) {
  604. console.log("validated");
  605. }
  606. console.log("didnt validate");
  607. });
  608. $('#registerSubmit').click(function() {
  609. if ($('#registration').smkValidate()) {
  610. console.log("validated");
  611. }
  612. console.log("didnt validate");
  613. User.processRegistration();
  614. });
  615. $("#editInfo").click(function(){
  616. $( "div[id^='editInfoDiv']" ).toggle();
  617. $( "div[id^='buttonsDiv']" ).toggle();
  618. });
  619. $("#goBackButtons").click(function(){
  620. $( "div[id^='editInfoDiv']" ).toggle();
  621. $( "div[id^='buttonsDiv']" ).toggle();
  622. });
  623. $("#switchForgot").click(function(){
  624. $( "form[id^='login']" ).toggle();
  625. $( "form[id^='forgotPassword']" ).toggle();
  626. $("#switchForgot").toggle();
  627. });
  628. //Sign in
  629. $(".log-in").click(function(e){
  630. var e1 = document.querySelector(".log-in"),
  631. e2 = document.querySelector(".login-modal");
  632. cta(e1, e2, {relativeToWindow: true}, function () {
  633. $('.login-modal').modal("show");
  634. });
  635. e.preventDefault();
  636. });
  637. //Logout
  638. $(".logout").click(function(e){
  639. var el1 = document.querySelector(".logout"),
  640. el2 = document.querySelector(".logout-modal");
  641. cta(el1, el2, {relativeToWindow: true}, function () {
  642. $('.logout-modal').modal("show");
  643. });
  644. e.preventDefault();
  645. });
  646. //Members Sidebar
  647. $(".show-members").click(function(e){
  648. var e_s1 = document.querySelector(".show-members"),
  649. e_s2 = document.querySelector("#members-sidebar");
  650. cta(e_s1, e_s2, {relativeToWindow: true}, function () {
  651. $('#members-sidebar').addClass('members-sidebar-open');
  652. });
  653. e.preventDefault();
  654. });
  655. $('.close-members-sidebar').click(function(){
  656. $('#members-sidebar').removeClass('members-sidebar-open');
  657. });
  658. $(document).ready(function(){
  659. defaultTab = $("li[class^='tab-item active']").attr("id");
  660. if (defaultTab){
  661. defaultTab = defaultTab.substr(0, defaultTab.length-1);
  662. }else{
  663. defaultTabNone = $("li[class^='tab-item']").attr("id");
  664. if (defaultTabNone){
  665. $("li[class^='tab-item']").first().attr("class", "tab-item active");
  666. defaultTab = defaultTabNone.substr(0, defaultTabNone.length-1);
  667. }
  668. }
  669. if (defaultTab){
  670. $("#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 allow-top-navigation" allowfullscreen="true" webkitallowfullscreen="true" mozallowfullscreen="true" frameborder="0" style="width:100%; height:100%;" src="'+defaultTab+'"></iframe></div>');
  671. }
  672. if (defaultTab == null){
  673. $("div[id^='tabEmpty']").show();
  674. <?php if($needSetup == "No" && $configReady == "Yes") : if(!$USER->authenticated) : ?>
  675. $('.login-modal').modal("show");
  676. <?php endif; endif; ?>
  677. }
  678. if ($(location).attr('hash')){
  679. var getHash = $(location).attr('hash').substr(1).replace("%20", " ").replace("_", " ");
  680. var gotHash = getHash.toLowerCase();
  681. var getLiTab = $("li[name^='" + gotHash + "']");
  682. getLiTab.trigger("click");
  683. }
  684. setHeight();
  685. });
  686. $(function () {
  687. <?php if(!empty($USER->info_log)) : ?>
  688. $.smkAlert({
  689. position: 'top-left',
  690. text: '<?php echo printArray($USER->info_log);?>',
  691. type: 'info'
  692. });
  693. <?php endif; ?>
  694. <?php if(!empty($USER->error_log)) : ?>
  695. $.smkAlert({
  696. position: 'top-left',
  697. text: '<?php echo printArray($USER->error_log); ?>',
  698. type: 'warning'
  699. });
  700. <?php endif; ?>
  701. });
  702. $('#reload').on('click tap', function(){
  703. $("i[class^='mdi mdi-refresh']").attr("class", "mdi mdi-refresh fa-spin");
  704. var activeFrame = $('#content').find('.active').children('iframe');
  705. activeFrame.attr('src', activeFrame.attr('src'));
  706. var refreshBox = $('#content').find('.active');
  707. $("<div class='refresh-preloader'><div class='la-timer la-dark'><div></div></div></div>").appendTo(refreshBox).fadeIn(10);
  708. setTimeout(function(){
  709. var refreshPreloader = refreshBox.find('.refresh-preloader'),
  710. deletedRefreshBox = refreshPreloader.fadeOut(300, function(){
  711. refreshPreloader.remove();
  712. $("i[class^='mdi mdi-refresh fa-spin']").attr("class", "mdi mdi-refresh");
  713. });
  714. },500);
  715. });
  716. $("li[id^='settings.phpx']").on('click tap', function(){
  717. $("img[id^='settings-icon']").attr("class", "fa-spin");
  718. $("i[id^='settings-icon']").attr("class", "fa fa-cog fa-spin");
  719. setTimeout(function(){
  720. $("img[id^='settings-icon']").attr("class", "");
  721. $("i[id^='settings-icon']").attr("class", "fa fa-cog");
  722. },1000);
  723. });
  724. $('#logoutSubmit').on('click tap', function(){
  725. $( "#logout" ).submit();
  726. });
  727. $(window).resize(function(){
  728. setHeight();
  729. });
  730. $("li[class^='tab-item']").on('click vclick', function(){
  731. var thisidfull = $(this).attr("id");
  732. var thisid = thisidfull.substr(0, thisidfull.length-1);
  733. var currentframe = $("div[data-content-url^='"+thisid+"']");
  734. if (currentframe.attr("class") == "iframe active") {
  735. console.log(thisid + " is active already");
  736. }else if (currentframe.attr("class") == "iframe hidden") {
  737. console.log(thisid + " is active already but hidden");
  738. $("div[class^='iframe active']").attr("class", "iframe hidden");
  739. currentframe.attr("class", "iframe active");
  740. setHeight();
  741. $("li[class^='tab-item active']").attr("class", "tab-item");
  742. $(this).attr("class", "tab-item active");
  743. }else {
  744. if ($(this).attr("window") == "true") {
  745. window.open(thisid,'_blank');
  746. }else {
  747. console.log(thisid + " make new div");
  748. $("div[class^='iframe active']").attr("class", "iframe hidden");
  749. $( '<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" );
  750. setHeight();
  751. $("li[class^='tab-item active']").attr("class", "tab-item");
  752. $(this).attr("class", "tab-item active");
  753. }
  754. }
  755. });
  756. </script>
  757. </body>
  758. </html>