tab-config-customize.twig 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. <div class="tab-pane fade" id="tab-config-customize" role="tabpanel" aria-labelledby="tab-config-customize">
  2. <div class="card mb-4">
  3. <div class="card-header d-flex fs-5">
  4. <button class="btn d-md-none flex-grow-1 text-start" data-bs-target="#collapse-tab-config-customize" data-bs-toggle="collapse" aria-controls="collapse-tab-config-customize">
  5. {{ lang.admin.customize }}
  6. </button>
  7. <span class="d-none d-md-block">{{ lang.admin.customize }}</span>
  8. </div>
  9. <div id="collapse-tab-config-customize" class="card-body collapse" data-bs-parent="#admin-content">
  10. <legend><i class="bi bi-file-image"></i> {{ lang.admin.change_logo }}</legend><hr />
  11. <p class="text-muted">{{ lang.admin.logo_info }}</p>
  12. <form class="form-inline" role="form" method="post" enctype="multipart/form-data">
  13. <div class="mb-4">
  14. <label for="main_logo_input" class="form-label">{{ lang.admin.logo_normal_label }}</label>
  15. <input class="form-control" id="main_logo_input" type="file" name="main_logo" accept="image/gif, image/jpeg, image/pjpeg, image/x-png, image/png, image/svg+xml">
  16. </div>
  17. <div class="mb-4">
  18. <label for="main_logo_dark_input" class="form-label">{{ lang.admin.logo_dark_label }}</label>
  19. <input class="form-control" id="main_logo_dark_input" type="file" name="main_logo_dark" accept="image/gif, image/jpeg, image/pjpeg, image/x-png, image/png, image/svg+xml">
  20. </div>
  21. <button name="submit_main_logo" type="submit" class="btn btn-sm d-block d-sm-inline btn-secondary"><i class="bi bi-upload"></i> {{ lang.admin.upload }}</button>
  22. </form>
  23. {% if logo or logo_dark %}
  24. <div class="row mt-4">
  25. <div class="col-sm-4">
  26. {% if logo %}
  27. {% include 'admin/customize/logo.twig' %}
  28. {% endif %}
  29. {% if logo_dark %}
  30. {% include 'admin/customize/logo.twig' with {'logo': logo_dark, 'logo_specs': logo_dark_specs, 'dark': 1} %}
  31. {% endif %}
  32. <hr>
  33. <form class="form-inline" role="form" method="post">
  34. <p><button name="reset_main_logo" type="submit" class="btn btn-sm d-block d-sm-inline btn-secondary">{{ lang.admin.reset_default }}</button></p>
  35. </form>
  36. </div>
  37. </div>
  38. {% endif %}
  39. <legend style="padding-top:20px" unselectable="on">{{ lang.admin.ip_check }}</legend><hr />
  40. <div id="ip_check">
  41. <form class="form" data-id="ip_check" role="form" method="post">
  42. <div class="mb-4">
  43. <input class="form-check-input" type="checkbox" value="1" name="ip_check_opt_in" id="ip_check_opt_in" {% if ip_check == 1 %}checked{% endif %}>
  44. <label class="form-check-label" for="ip_check_opt_in">
  45. {{ lang.admin.ip_check_opt_in|raw }}
  46. </label>
  47. </div>
  48. <p><div class="btn-group">
  49. <button class="btn btn-sm btn-xs-half d-block d-sm-inline btn-success" data-action="edit_selected" data-item="admin" data-id="ip_check" data-reload="no" data-api-url='edit/ip_check' data-api-attr='{}' href="#"><i class="bi bi-check-lg"></i> {{ lang.admin.save }}</button>
  50. </div></p>
  51. </form>
  52. </div>
  53. <legend style="padding-top:20px" unselectable="on">{{ lang.admin.login_page }}</legend><hr />
  54. <div>
  55. <form class="form" data-id="custom_login" role="form" method="post">
  56. <p class="text-muted">{{ lang.admin.quicklink_text }}</p>
  57. <div class="ms-2 mb-1">
  58. <input class="form-check-input" type="checkbox" value="1" name="hide_user_quicklink" id="hide_user_quicklink" {% if custom_login.hide_user_quicklink == 1 %}checked{% endif %}>
  59. <label class="form-check-label" for="hide_user_quicklink">
  60. {{ lang.admin.user_quicklink|raw }}
  61. </label>
  62. </div>
  63. <div class="ms-2 mb-1">
  64. <input class="form-check-input" type="checkbox" value="1" name="hide_domainadmin_quicklink" id="hide_domainadmin_quicklink" {% if custom_login.hide_domainadmin_quicklink == 1 %}checked{% endif %}>
  65. <label class="form-check-label" for="hide_domainadmin_quicklink">
  66. {{ lang.admin.domainadmin_quicklink|raw }}
  67. </label>
  68. </div>
  69. <div class="ms-2 mb-4">
  70. <input class="form-check-input" type="checkbox" value="1" name="hide_admin_quicklink" id="hide_admin_quicklink" {% if custom_login.hide_admin_quicklink == 1 %}checked{% endif %}>
  71. <label class="form-check-label" for="hide_admin_quicklink">
  72. {{ lang.admin.admin_quicklink|raw }}
  73. </label>
  74. </div>
  75. <p class="text-muted">{{ lang.admin.force_sso_text|raw }}</p>
  76. <div class="ms-2 mb-4">
  77. <input class="form-check-input" type="checkbox" value="1" name="force_sso" id="force_sso" {% if custom_login.force_sso == 1 %}checked{% endif %}>
  78. <label class="form-check-label" for="force_sso">
  79. {{ lang.admin.force_sso|raw }}
  80. </label>
  81. </div>
  82. <p><div class="btn-group">
  83. <button class="btn btn-sm btn-xs-half d-block d-sm-inline btn-success" data-action="edit_selected" data-item="admin" data-id="custom_login" data-reload="no" data-api-url='edit/custom_login' data-api-attr='{}' href="#"><i class="bi bi-check-lg"></i> {{ lang.admin.save }}</button>
  84. </div></p>
  85. </form>
  86. </div>
  87. <legend style="padding-top:20px">{{ lang.admin.app_links }}</legend><hr />
  88. <p class="text-muted">{{ lang.admin.merged_vars_hint|raw }}</p>
  89. <form class="form-inline" data-id="app_links" role="form" method="post">
  90. <table class="table table-condensed" style="white-space: nowrap;" id="app_link_table">
  91. <tr>
  92. <th>{{ lang.admin.app_name }}</th>
  93. <th>{{ lang.admin.link }}</th>
  94. <th>{{ lang.admin.user_link }}</th>
  95. <th style="width:125px;">{{ lang.admin.app_hide }}</th>
  96. <th style="width:100px;">&nbsp;</th>
  97. </tr>
  98. {% for row in app_links %}
  99. {% for key, val in row %}
  100. <tr>
  101. <td><input class="input-sm input-xs-lg form-control" data-id="app_links" type="text" name="app" required value="{{ key }}"></td>
  102. <td><input class="input-sm input-xs-lg form-control" data-id="app_links" type="text" name="href" required value="{{ val.link }}"></td>
  103. <td><input class="input-sm input-xs-lg form-control" data-id="app_links" type="text" name="user_href" required value="{{ val.user_link }}"></td>
  104. <td>
  105. <div class="d-flex align-items-center justify-content-center" style="height: 33.5px">
  106. <input data-id="app_links" type="hidden" name="hide" {% if val.hide %}value="1"{% else %}value="0"{% endif %}>
  107. <input class="form-check-input app_hide" type="checkbox" value="1" {% if val.hide %}checked{% endif %}>
  108. </div>
  109. </td>
  110. <td><a href="#" role="button" class="btn btn-sm btn-xs-lg btn-secondary h-100 w-100" type="button">{{ lang.admin.remove_row }}</a></td>
  111. </tr>
  112. {% endfor %}
  113. {% endfor %}
  114. {% for app in mailcow_apps %}
  115. <tr>
  116. <td><input class="input-sm input-xs-lg form-control" value="{{ app.name }}" disabled></td>
  117. <td><input class="input-sm input-xs-lg form-control" value="{{ app.link }}" disabled></td>
  118. <td><input class="input-sm input-xs-lg form-control" value="{{ app.user_link }}" disabled></td>
  119. <td>
  120. <div class="d-flex align-items-center justify-content-center" style="height: 33.5px">
  121. <input class="form-check-input" data-id="app_links" type="checkbox" name="hide" value="1" disabled {% if app.hide %}checked{% endif %}>
  122. </div>
  123. </td>
  124. <td><a href="#" role="button" class="btn btn-sm btn-xs-lg btn-secondary h-100 w-100 disabled" type="button">{{ lang.admin.remove_row }}</a></td>
  125. </tr>
  126. {% endfor %}
  127. </table>
  128. <p><div class="btn-group">
  129. <button class="btn btn-sm btn-xs-half d-block d-sm-inline btn-success" data-action="edit_selected" data-item="admin" data-id="app_links" data-reload="no" data-api-url='edit/app_links' data-api-attr='{}' href="#"><i class="bi bi-check-lg"></i> {{ lang.admin.save }}</button>
  130. <button class="btn btn-sm btn-xs-half d-block d-sm-inline btn-secondary" type="button" id="add_app_link_row">{{ lang.admin.add_row }}</button>
  131. </div></p>
  132. </form>
  133. <legend data-bs-target="#ui_texts" style="padding-top:20px" unselectable="on">{{ lang.admin.ui_texts }}</legend><hr />
  134. <div id="ui_texts">
  135. <form class="form" data-id="uitexts" role="form" method="post">
  136. <div class="mb-2">
  137. <label for="uitests_title_name">{{ lang.admin.title_name }}:</label>
  138. <input type="text" class="form-control" id="uitests_title_name" name="title_name" placeholder="mailcow UI" value="{{ ui_texts.title_name|raw }}">
  139. </div>
  140. <div class="mb-2">
  141. <label for="uitests_main_name">{{ lang.admin.main_name }}:</label>
  142. <input type="text" class="form-control" id="uitests_main_name" name="main_name" placeholder="mailcow UI" value="{{ ui_texts.main_name|raw }}">
  143. </div>
  144. <div class="mb-2">
  145. <label for="uitests_apps_name">{{ lang.admin.apps_name }}:</label>
  146. <input type="text" class="form-control" id="uitests_apps_name" name="apps_name" placeholder="{{ lang.header.apps }}" value="{{ ui_texts.apps_name|raw }}">
  147. </div>
  148. <div class="mb-4">
  149. <label for="help_text">{{ lang.admin.help_text }}:</label>
  150. <textarea class="form-control" id="help_text" name="help_text" rows="7">{{ ui_texts.help_text|raw }}</textarea>
  151. </div>
  152. <hr>
  153. <div>
  154. <p class="text-muted">{{ lang.admin.ui_header_announcement_help }}</p>
  155. <label for="ui_announcement_type">{{ lang.admin.ui_header_announcement }}:</label>
  156. <div class="row">
  157. <div class="col-12 col-md-6 col-lg-4 col-xl-3">
  158. <p><select multiple data-width="100%" id="ui_announcement_type" name="ui_announcement_type" class="selectpicker show-tick" data-max-options="1" title="{{ lang.admin.ui_header_announcement_select }}">
  159. <option {% if ui_texts.ui_announcement_type == 'info' %}selected{% endif %} value="info">{{ lang.admin.ui_header_announcement_type_info }}</option>
  160. <option {% if ui_texts.ui_announcement_type == 'warning' %}selected{% endif %} value="warning">{{ lang.admin.ui_header_announcement_type_warning }}</option>
  161. <option {% if ui_texts.ui_announcement_type == 'danger' %}selected{% endif %} value="danger">{{ lang.admin.ui_header_announcement_type_danger }}</option>
  162. </select></p>
  163. </div>
  164. </div>
  165. <p><textarea class="form-control" id="ui_announcement_text" name="ui_announcement_text" rows="7">{{ ui_texts.ui_announcement_text }}</textarea></p>
  166. <div class="form-check">
  167. <label>
  168. <input type="checkbox" name="ui_announcement_active" class="form-check-input" {% if ui_texts.ui_announcement_active == 1 %}checked{% endif %}> {{ lang.admin.ui_header_announcement_active }}
  169. </label>
  170. </div>
  171. </div>
  172. <hr>
  173. <div class="mb-4">
  174. <label for="ui_footer">{{ lang.admin.ui_footer }}:</label>
  175. <textarea class="form-control" id="ui_footer" name="ui_footer" rows="7">{{ ui_texts.ui_footer }}</textarea>
  176. </div>
  177. <button class="btn btn-sm d-block d-sm-inline btn-success" data-action="edit_selected" data-item="ui" data-id="uitexts" data-api-url='edit/ui_texts' data-api-attr='{}' href="#"><i class="bi bi-check-lg"></i> {{ lang.admin.save }}</button>
  178. </form>
  179. </div>
  180. </div>
  181. </div>
  182. </div>