header.inc.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. <!DOCTYPE html>
  2. <html lang="<?= $_SESSION['mailcow_locale'] ?>">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=0">
  7. <meta name="theme-color" content="#F5D76E"/>
  8. <meta http-equiv="Referrer-Policy" content="same-origin">
  9. <title><?=$UI_TEXTS['title_name'];?></title>
  10. <?php
  11. if (preg_match("/mailbox/i", $_SERVER['REQUEST_URI'])) {
  12. $css_minifier->add('/web/css/site/mailbox.css');
  13. }
  14. if (preg_match("/admin/i", $_SERVER['REQUEST_URI'])) {
  15. $css_minifier->add('/web/css/site/admin.css');
  16. }
  17. if (preg_match("/user/i", $_SERVER['REQUEST_URI'])) {
  18. $css_minifier->add('/web/css/site/user.css');
  19. }
  20. if (preg_match("/edit/i", $_SERVER['REQUEST_URI'])) {
  21. $css_minifier->add('/web/css/site/edit.css');
  22. }
  23. if (preg_match("/quarantine/i", $_SERVER['REQUEST_URI'])) {
  24. $css_minifier->add('/web/css/site/quarantine.css');
  25. }
  26. if (preg_match("/debug/i", $_SERVER['REQUEST_URI'])) {
  27. $css_minifier->add('/web/css/site/debug.css');
  28. }
  29. if ($_SERVER['REQUEST_URI'] == '/') {
  30. $css_minifier->add('/web/css/site/index.css');
  31. }
  32. ?>
  33. <style><?=$css_minifier->minify();?></style>
  34. <?php if (strtolower(trim($DEFAULT_THEME)) != "lumen"): ?>
  35. <link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/bootswatch/3.3.7/<?= strtolower(trim($DEFAULT_THEME)); ?>/bootstrap.min.css">
  36. <?php endif; ?>
  37. <link rel="shortcut icon" href="/favicon.png" type="image/png">
  38. <link rel="icon" href="/favicon.png" type="image/png">
  39. </head>
  40. <body id="top">
  41. <div class="overlay"></div>
  42. <nav class="navbar navbar-default navbar-fixed-top" role="navigation">
  43. <div class="container-fluid">
  44. <div class="navbar-header">
  45. <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
  46. <span class="icon-bar"></span>
  47. <span class="icon-bar"></span>
  48. <span class="icon-bar"></span>
  49. </button>
  50. <a class="navbar-brand" href="/"><img alt="mailcow-logo" src="<?=($main_logo = customize('get', 'main_logo')) ? $main_logo : '/img/cow_mailcow.svg';?>"></a>
  51. </div>
  52. <div id="navbar" class="navbar-collapse collapse">
  53. <ul class="nav navbar-nav navbar-right">
  54. <?php
  55. if (isset($_SESSION['mailcow_locale'])) {
  56. ?>
  57. <li class="dropdown<?=(isset($_SESSION['mailcow_locale']) && count($AVAILABLE_LANGUAGES) === 1) ? ' lang-link-disabled"' : '' ?>">
  58. <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"><span class="lang-sm lang-lbl" lang="<?= $_SESSION['mailcow_locale']; ?>"></span><span class="caret"></span></a>
  59. <ul class="dropdown-menu" role="menu">
  60. <?php
  61. foreach ($AVAILABLE_LANGUAGES as $language) {
  62. ?>
  63. <li<?= ($_SESSION['mailcow_locale'] == $language) ? ' class="active"' : ''; ?>><a href="?<?= http_build_query(array_merge($_GET, array('lang' => $language))); ?>"><span class="lang-xs lang-lbl-full" lang="<?= $language; ?>"></span></a></li>
  64. <?php
  65. }
  66. ?>
  67. </ul>
  68. </li>
  69. <?php
  70. }
  71. if (isset($_SESSION['mailcow_cc_role'])) {
  72. ?>
  73. <li class="dropdown">
  74. <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"><?= $lang['header']['mailcow_settings']; ?> <span class="caret"></span></a>
  75. <ul class="dropdown-menu" role="menu">
  76. <?php
  77. if (isset($_SESSION['mailcow_cc_role'])) {
  78. if ($_SESSION['mailcow_cc_role'] == 'admin') {
  79. ?>
  80. <li<?= (preg_match("/admin/i", $_SERVER['REQUEST_URI'])) ? ' class="active"' : ''; ?>><a href="/admin"><?= $lang['header']['administration']; ?></a></li>
  81. <li<?= (preg_match("/debug/i", $_SERVER['REQUEST_URI'])) ? ' class="active"' : ''; ?>><a href="/debug"><?= $lang['header']['debug']; ?></a></li>
  82. <?php
  83. }
  84. if ($_SESSION['mailcow_cc_role'] == 'admin' || $_SESSION['mailcow_cc_role'] == 'domainadmin') {
  85. ?>
  86. <li<?= (preg_match("/mailbox/i", $_SERVER['REQUEST_URI'])) ? ' class="active"' : ''; ?>><a href="/mailbox"><?= $lang['header']['mailboxes']; ?></a></li>
  87. <?php
  88. }
  89. if ($_SESSION['mailcow_cc_role'] != 'admin') {
  90. ?>
  91. <li<?= (preg_match("/user/i", $_SERVER['REQUEST_URI'])) ? ' class="active"' : ''; ?>><a href="/user"><?= $lang['header']['user_settings']; ?></a></li>
  92. <?php
  93. }
  94. }
  95. ?>
  96. </ul>
  97. </li>
  98. <?php
  99. if (isset($_SESSION['mailcow_cc_role'])) {
  100. ?>
  101. <li<?= (preg_match("/quarantine/i", $_SERVER['REQUEST_URI'])) ? ' class="active"' : ''; ?>><a href="/quarantine"><span class="glyphicon glyphicon-briefcase"></span> <?= $lang['header']['quarantine']; ?></a></li>
  102. <?php
  103. }
  104. if ($_SESSION['mailcow_cc_role'] == 'admin') {
  105. ?>
  106. <li><a href data-toggle="modal" data-container="sogo-mailcow" data-target="#RestartContainer"><span class="glyphicon glyphicon-refresh"></span> <?= $lang['header']['restart_sogo']; ?></a></li>
  107. <?php
  108. }
  109. ?>
  110. <li class="dropdown">
  111. <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"><span class="glyphicon glyphicon-link"></span> <?= $lang['header']['apps']; ?> <span class="caret"></span></a>
  112. <ul class="dropdown-menu" role="menu">
  113. <?php
  114. foreach ($MAILCOW_APPS as $app):
  115. ?>
  116. <li title="<?= htmlspecialchars($app['description']); ?>"><a href="<?= htmlspecialchars($app['link']); ?>"><?= htmlspecialchars($app['name']); ?></a></li>
  117. <?php
  118. endforeach;
  119. $app_links = customize('get', 'app_links');
  120. if ($app_links) {
  121. foreach ($app_links as $row) {
  122. foreach ($row as $key => $val):
  123. ?>
  124. <li><a href="<?= htmlspecialchars($val); ?>"><?= htmlspecialchars($key); ?></a></li>
  125. <?php
  126. endforeach;
  127. }
  128. }
  129. ?>
  130. </ul>
  131. </li>
  132. <?php
  133. }
  134. if (!isset($_SESSION['dual-login']) && isset($_SESSION['mailcow_cc_username'])):
  135. ?>
  136. <li class="logged-in-as"><a href="#" onclick="logout.submit()"><b class="username-lia"><?= htmlspecialchars($_SESSION['mailcow_cc_username']); ?></b> <span class="glyphicon glyphicon-log-out"></span></a></li>
  137. <?php
  138. elseif (isset($_SESSION['dual-login'])):
  139. ?>
  140. <li class="logged-in-as"><a href="#" onclick="logout.submit()"><b class="username-lia"><?= htmlspecialchars($_SESSION['mailcow_cc_username']); ?> <span class="text-info">(<?= htmlspecialchars($_SESSION['dual-login']['username']); ?>)</span> </b><span class="glyphicon glyphicon-log-out"></span></a></li>
  141. <?php
  142. endif;
  143. ?>
  144. </ul>
  145. </div><!--/.nav-collapse -->
  146. </div><!--/.container-fluid -->
  147. </nav>
  148. <form action="/" method="post" id="logout"><input type="hidden" name="logout"></form>