4
0

login.php 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <?php
  2. $GLOBALS['organizrPages'][] = 'login';
  3. function get_page_login($Organizr)
  4. {
  5. if (!$Organizr) {
  6. $Organizr = new Organizr();
  7. }
  8. if ((!$Organizr->hasDB())) {
  9. return false;
  10. }
  11. $hideOrganizrLogin = ($Organizr->checkoAuth()) ? 'collapse' : 'collapse in';
  12. $hideOrganizrLoginHeader = ($Organizr->checkoAuthOnly()) ? 'hidden' : '';
  13. $hideOrganizrLoginHeader2 = ($Organizr->checkoAuth()) ? '' : 'hidden';
  14. $hideOrganizrRecoveryPassword = ($Organizr->config['disableRecoverPass']) ? 'hidden' : '';
  15. $customForgotPasswordText = (empty($Organizr->config['customForgotPassText'])) ? 'Enter your Email and instructions will be sent to you!' : $Organizr->config['customForgotPassText'];
  16. $customForgotPasswordText = ($Organizr->config['disableRecoverPass']) ? 'Disabled' : $customForgotPasswordText;
  17. return '
  18. <script>
  19. if(activeInfo.settings.login.rememberMe){
  20. $(\'#checkbox-login\').prop(\'checked\',true);
  21. }
  22. </script>
  23. <section id="wrapper" class="login-register">
  24. <div class="login-box login-sidebar animated slideInRight">
  25. <div class="white-box">
  26. <form class="form-horizontal" id="loginform" onsubmit="return false;">
  27. <input id="login-attempts" class="form-control" name="loginAttempts" type="hidden">
  28. <a href="javascript:void(0)" class="text-center db visible-xs" id="login-logo">' . $Organizr->logoOrText() . '</a>
  29. <div id="oAuth-div" class="form-group hidden">
  30. <div class="col-xs-12">
  31. <div class="panel panel-success animated tada">
  32. <div class="panel-heading">oAuth Successful - Please wait...</div>
  33. </div>
  34. </div>
  35. </div>
  36. <div id="tfa-div" class="form-group hidden">
  37. <div class="col-xs-12">
  38. <div class="panel panel-warning animated tada">
  39. <div class="panel-heading"> 2FA
  40. <div class="pull-right"><a href="#" data-perform="panel-collapse"><i class="ti-minus"></i></a> <a href="#" data-perform="panel-dismiss"><i class="ti-close"></i></a> </div>
  41. </div>
  42. <div class="panel-wrapper collapse in" aria-expanded="true">
  43. <div class="panel-body">
  44. <div class="input-group" style="width: 100%;">
  45. <div class="input-group-addon hidden-xs"><i class="ti-lock"></i></div>
  46. <input type="text" class="form-control tfa-input" name="tfaCode" placeholder="Code" data-lpignore="true" autocomplete="off" autocorrect="off" autocapitalize="off" maxlength="6" spellcheck="false" autofocus="">
  47. </div>
  48. <button class="btn btn-warning btn-lg btn-block text-uppercase waves-effect waves-light login-button m-t-10" type="submit" lang="en">Login</button>
  49. </div>
  50. </div>
  51. </div>
  52. </div>
  53. </div>
  54. <div class="panel-group" id="login-panels" data-type="accordion" aria-multiselectable="true" role="tablist">
  55. <!-- ORGANIZR LOGIN -->
  56. <div class="panel">
  57. <div class="panel-heading bg-org ' . $hideOrganizrLoginHeader . ' ' . $hideOrganizrLoginHeader2 . '" id="organizr-login-heading" role="tab">
  58. <a class="panel-title collapsed" data-toggle="collapse" href="#organizr-login-collapse" data-parent="#login-panels" aria-expanded="false" aria-controls="organizr-login-collapse">
  59. <img class="lazyload loginTitle" data-src="plugins/images/organizr/logo-no-border.png"> &nbsp;
  60. <span class="text-uppercase fw300" lang="en">Login with Organizr</span>
  61. </a>
  62. <div class="clearfix"></div>
  63. </div>
  64. <div class="panel-collapse ' . $hideOrganizrLogin . '" id="organizr-login-collapse" aria-labelledby="organizr-login-heading" role="tabpanel">
  65. <div class="panel-body">
  66. <div class="form-group">
  67. <div class="col-xs-12">
  68. <input id="login-username-Input" class="form-control" name="username" type="text" required="" placeholder="Username" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false" lang="en" autofocus>
  69. </div>
  70. </div>
  71. <div class="form-group">
  72. <div class="col-xs-12">
  73. <input id="login-password-Input" class="form-control" name="password" type="password" required="" placeholder="Password" lang="en">
  74. </div>
  75. </div>
  76. <div class="form-group">
  77. <div class="col-md-12">
  78. <div class="checkbox checkbox-primary pull-left p-t-0 remember-me">
  79. <input id="checkbox-login" name="remember" type="checkbox">
  80. <label for="checkbox-login" lang="en">Remember Me</label>
  81. </div>
  82. </div>
  83. </div>
  84. <div class="form-group text-center m-t-20 m-b-0">
  85. <div class="col-xs-12">
  86. <button class="btn btn-info btn-lg btn-block text-uppercase waves-effect waves-light login-button" type="submit" lang="en">Login</button>
  87. </div>
  88. </div>
  89. <div class="form-group m-b-0">
  90. <div class="col-sm-12 text-center">
  91. <input id="oAuth-Input" class="form-control" name="oAuth" type="hidden">
  92. <input id="oAuthType-Input" class="form-control" name="oAuthType" type="hidden">
  93. ' . $Organizr->showLogin() . '
  94. </div>
  95. </div>
  96. </div>
  97. </div>
  98. </div>
  99. <!-- END ORGANIZR LOGIN -->
  100. <!-- PLEX OAUTH LOGIN -->
  101. ' . $Organizr->showoAuth() . '
  102. <!-- END PLEX OAUTH LOGIN -->
  103. </div>
  104. </form>
  105. <form class="form-horizontal form-material hidden" id="registerForm" onsubmit="return false;">
  106. <div class="form-group m-t-40">
  107. <div class="col-xs-12">
  108. <input class="form-control" type="text" name="registrationPassword" required="" placeholder="Registration Password" lang="en" autofocus>
  109. </div>
  110. </div>
  111. <div class="form-group">
  112. <div class="col-xs-12">
  113. <input class="form-control" name="username" type="text" required="" placeholder="Username" lang="en">
  114. </div>
  115. </div>
  116. <div class="form-group">
  117. <div class="col-xs-12">
  118. <input class="form-control" name="email" type="text" required="" placeholder="Email" lang="en">
  119. </div>
  120. </div>
  121. <div class="form-group">
  122. <div class="col-xs-12">
  123. <input class="form-control" name="password" type="password" required="" placeholder="Password" lang="en">
  124. </div>
  125. </div>
  126. <div class="form-group text-center m-t-20">
  127. <div class="col-xs-12">
  128. <button class="btn btn-info btn-lg btn-block text-uppercase waves-effect waves-light register-button" type="submit" lang="en">Register</button>
  129. </div>
  130. </div>
  131. <div class="form-group text-center m-t-20">
  132. <div class="col-xs-12">
  133. <button id="leave-registration" class="btn btn-primary btn-lg btn-block text-uppercase waves-effect waves-light" type="button" lang="en">Go Back</button>
  134. </div>
  135. </div>
  136. </form>
  137. <form class="form-horizontal" id="recoverform" onsubmit="return false;">
  138. <div class="form-group ">
  139. <div class="col-xs-12">
  140. <h3 lang="en">Recover Password</h3>
  141. <p class="text-muted" lang="en">' . $customForgotPasswordText . '</p>
  142. </div>
  143. </div>
  144. <div class="form-group ' . $hideOrganizrRecoveryPassword . '">
  145. <div class="col-xs-12">
  146. <input id="recover-input" class="form-control" name="email" type="text" placeholder="Email" lang="en" required>
  147. </div>
  148. </div>
  149. <div class="form-group text-center m-t-20 ' . $hideOrganizrRecoveryPassword . '">
  150. <div class="col-xs-12">
  151. <button class="btn btn-primary btn-lg btn-block text-uppercase waves-effect waves-light reset-button" type="submit" lang="en">Reset</button>
  152. </div>
  153. </div>
  154. <div class="form-group text-center m-t-20">
  155. <div class="col-xs-12">
  156. <button id="leave-recover" class="btn btn-primary btn-lg btn-block text-uppercase waves-effect waves-light" type="button" lang="en">Go Back</button>
  157. </div>
  158. </div>
  159. </form>
  160. </div>
  161. </div>
  162. </section>
  163. ';
  164. }