header.inc.php 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  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">
  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. ?>
  30. <style><?=$css_minifier->minify();?></style>
  31. <?php if (strtolower(trim($DEFAULT_THEME)) != "lumen"): ?>
  32. <link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/bootswatch/3.3.7/<?= strtolower(trim($DEFAULT_THEME)); ?>/bootstrap.min.css">
  33. <?php endif; ?>
  34. <link rel="shortcut icon" href="/favicon.png" type="image/png">
  35. <link rel="icon" href="/favicon.png" type="image/png">
  36. </head>
  37. <body id="top">
  38. <div class="overlay"></div>
  39. <nav class="navbar navbar-default navbar-fixed-top" role="navigation">
  40. <div class="container-fluid">
  41. <div class="navbar-header">
  42. <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
  43. <span class="icon-bar"></span>
  44. <span class="icon-bar"></span>
  45. <span class="icon-bar"></span>
  46. </button>
  47. <a class="navbar-brand" href="/"><img alt="mailcow-logo" src="<?=($main_logo = customize('get', 'main_logo')) ? $main_logo : '/img/cow_mailcow.svg';?>"></a>
  48. </div>
  49. <div id="navbar" class="navbar-collapse collapse">
  50. <ul class="nav navbar-nav navbar-right">
  51. <?php
  52. if (isset($_SESSION['mailcow_locale'])) {
  53. ?>
  54. <li class="dropdown<?=(isset($_SESSION['mailcow_locale']) && count($AVAILABLE_LANGUAGES) === 1) ? ' lang-link-disabled"' : '' ?>">
  55. <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>
  56. <ul class="dropdown-menu" role="menu">
  57. <?php
  58. foreach ($AVAILABLE_LANGUAGES as $language) {
  59. ?>
  60. <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>
  61. <?php
  62. }
  63. ?>
  64. </ul>
  65. </li>
  66. <?php
  67. }
  68. if (isset($_SESSION['mailcow_cc_role'])) {
  69. ?>
  70. <li class="dropdown">
  71. <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"><?= $lang['header']['mailcow_settings']; ?> <span class="caret"></span></a>
  72. <ul class="dropdown-menu" role="menu">
  73. <?php
  74. if (isset($_SESSION['mailcow_cc_role'])) {
  75. if ($_SESSION['mailcow_cc_role'] == 'admin') {
  76. ?>
  77. <li<?= (preg_match("/admin/i", $_SERVER['REQUEST_URI'])) ? ' class="active"' : ''; ?>><a href="/admin"><?= $lang['header']['administration']; ?></a></li>
  78. <li<?= (preg_match("/debug/i", $_SERVER['REQUEST_URI'])) ? ' class="active"' : ''; ?>><a href="/debug"><?= $lang['header']['debug']; ?></a></li>
  79. <?php
  80. }
  81. if ($_SESSION['mailcow_cc_role'] == 'admin' || $_SESSION['mailcow_cc_role'] == 'domainadmin') {
  82. ?>
  83. <li<?= (preg_match("/mailbox/i", $_SERVER['REQUEST_URI'])) ? ' class="active"' : ''; ?>><a href="/mailbox"><?= $lang['header']['mailboxes']; ?></a></li>
  84. <?php
  85. }
  86. if ($_SESSION['mailcow_cc_role'] != 'admin') {
  87. ?>
  88. <li<?= (preg_match("/user/i", $_SERVER['REQUEST_URI'])) ? ' class="active"' : ''; ?>><a href="/user"><?= $lang['header']['user_settings']; ?></a></li>
  89. <?php
  90. }
  91. }
  92. ?>
  93. </ul>
  94. </li>
  95. <?php
  96. if (isset($_SESSION['mailcow_cc_role'])) {
  97. ?>
  98. <li<?= (preg_match("/quarantine/i", $_SERVER['REQUEST_URI'])) ? ' class="active"' : ''; ?>><a href="/quarantine"><span class="glyphicon glyphicon-briefcase"></span> <?= $lang['header']['quarantine']; ?></a></li>
  99. <?php
  100. }
  101. if ($_SESSION['mailcow_cc_role'] == 'admin') {
  102. ?>
  103. <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>
  104. <?php
  105. }
  106. ?>
  107. <li class="dropdown">
  108. <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>
  109. <ul class="dropdown-menu" role="menu">
  110. <?php
  111. foreach ($MAILCOW_APPS as $app):
  112. ?>
  113. <li title="<?= htmlspecialchars($app['description']); ?>"><a href="<?= htmlspecialchars($app['link']); ?>"><?= htmlspecialchars($app['name']); ?></a></li>
  114. <?php
  115. endforeach;
  116. $app_links = customize('get', 'app_links');
  117. if ($app_links) {
  118. foreach ($app_links as $row) {
  119. foreach ($row as $key => $val):
  120. ?>
  121. <li><a href="<?= htmlspecialchars($val); ?>"><?= htmlspecialchars($key); ?></a></li>
  122. <?php
  123. endforeach;
  124. }
  125. }
  126. ?>
  127. </ul>
  128. </li>
  129. <?php
  130. }
  131. if (!isset($_SESSION['dual-login']) && isset($_SESSION['mailcow_cc_username'])):
  132. ?>
  133. <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>
  134. <?php
  135. elseif (isset($_SESSION['dual-login'])):
  136. ?>
  137. <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>
  138. <?php
  139. endif;
  140. ?>
  141. </ul>
  142. </div><!--/.nav-collapse -->
  143. </div><!--/.container-fluid -->
  144. </nav>
  145. <form action="/" method="post" id="logout"><input type="hidden" name="logout"></form>