tab-routing.twig 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. <div class="tab-pane fade" id="tab-routing" role="tabpanel" aria-labelledby="tab-routing">
  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-routing" data-bs-toggle="collapse" aria-controls="collapse-tab-routing">
  5. {{ lang.admin.relayhosts }}
  6. </button>
  7. <span class="d-none d-md-block">{{ lang.admin.relayhosts }}</span>
  8. </div>
  9. <div id="collapse-tab-routing" class="card-body collapse" data-bs-parent="#admin-content">
  10. <p class="mb-4">{{ lang.admin.relayhosts_hint|raw }}</p>
  11. <table id="relayhoststable" class="table table-striped dt-responsive w-100"></table>
  12. <div class="mass-actions-admin mb-4">
  13. <div class="btn-group btn-group-sm">
  14. <button type="button" id="toggle_multi_select_all" data-id="rlyhosts" class="btn btn-sm btn-xs-half d-block d-sm-inline btn-secondary">{{ lang.mailbox.toggle_all }}</button>
  15. <a class="btn btn-sm btn-xs-half d-block d-sm-inline btn-secondary dropdown-toggle" data-bs-toggle="dropdown" href="#">{{ lang.mailbox.quick_actions }}</a>
  16. <ul class="dropdown-menu top100">
  17. <li><a class="dropdown-item" data-action="edit_selected" data-id="rlyhosts" data-api-url='edit/relayhost' data-api-attr='{"active":"1"}' href="#">{{ lang.mailbox.activate }}</a></li>
  18. <li><a class="dropdown-item" data-action="edit_selected" data-id="rlyhosts" data-api-url='edit/relayhost' data-api-attr='{"active":"0"}' href="#">{{ lang.mailbox.deactivate }}</a></li>
  19. <li><hr class="dropdown-divider"></li>
  20. <li><a class="dropdown-item" data-action="delete_selected" data-id="rlyhosts" data-api-url='delete/relayhost' href="#">{{ lang.admin.remove }}</a></li>
  21. </ul>
  22. </div>
  23. </div>
  24. <legend>{{ lang.admin.add_relayhost }}</legend><hr />
  25. <p class="text-muted">{{ lang.admin.add_relayhost_hint|raw }}</p>
  26. <div class="row">
  27. <div class="col-md-8">
  28. <form class="form" data-id="rlyhost" role="form" method="post">
  29. <div class="mb-2">
  30. <label for="rlyhost_hostname">{{ lang.admin.host }}</label>
  31. <input class="form-control" id="rlyhost_hostname" name="hostname" placeholder='[0.0.0.0], [0.0.0.0]:25, host:25, host, [host]:25' required>
  32. </div>
  33. <div class="mb-2">
  34. <label for="rlyhost_username">{{ lang.admin.username }}</label>
  35. <input class="form-control" id="rlyhost_username" name="username">
  36. </div>
  37. <div class="mb-4">
  38. <label for="rlyhost_password">{{ lang.admin.password }}</label>
  39. <input class="form-control" id="rlyhost_password" name="password" type="password">
  40. </div>
  41. <button class="btn btn-sm d-block d-sm-inline btn-success" data-action="add_item" data-id="rlyhost" data-api-url='add/relayhost' data-api-attr='{}' href="#"><i class="bi bi-plus-lg"></i> {{ lang.admin.add }}</button>
  42. </form>
  43. </div>
  44. </div>
  45. </div>
  46. </div>
  47. <div class="card mb-4">
  48. <div class="card-header d-flex">
  49. <button class="btn d-md-none flex-grow-1 text-start" data-bs-target="#collapse-tab-maps" data-bs-toggle="collapse" aria-controls="collapse-tab-maps">
  50. {{ lang.admin.transport_maps }}
  51. </button>
  52. <span class="d-none d-md-block">{{ lang.admin.transport_maps }}</span>
  53. </div>
  54. <div id="collapse-tab-maps" class="card-body collapse" data-bs-parent="#admin-content">
  55. <p style="margin-bottom:40px">{{ lang.admin.transports_hint|raw }}</p>
  56. <table id="transportstable" class="table table-striped dt-responsive w-100"></table>
  57. <div class="mass-actions-admin mb-4">
  58. <div class="btn-group btn-group-sm">
  59. <button type="button" id="toggle_multi_select_all" data-id="transports" class="btn btn-sm btn-xs-half d-block d-sm-inline btn-secondary">{{ lang.mailbox.toggle_all }}</button>
  60. <a class="btn btn-sm btn-xs-half d-block d-sm-inline btn-secondary dropdown-toggle" data-bs-toggle="dropdown" href="#">{{ lang.mailbox.quick_actions }}</a>
  61. <ul class="dropdown-menu top100">
  62. <li><a class="dropdown-item" data-action="edit_selected" data-id="transports" data-api-url='edit/transport' data-api-attr='{"active":"1"}' href="#">{{ lang.mailbox.activate }}</a></li>
  63. <li><a class="dropdown-item" data-action="edit_selected" data-id="transports" data-api-url='edit/transport' data-api-attr='{"active":"0"}' href="#">{{ lang.mailbox.deactivate }}</a></li>
  64. <li><hr class="dropdown-divider"></li>
  65. <li><a class="dropdown-item" data-action="delete_selected" data-id="transports" data-api-url='delete/transport' href="#">{{ lang.admin.remove }}</a></li>
  66. </ul>
  67. </div>
  68. </div>
  69. <legend>{{ lang.admin.add_transport }}</legend><hr />
  70. <p class="text-muted">{{ lang.admin.add_transports_hint|raw }}</p>
  71. <div class="row">
  72. <div class="col-md-8">
  73. <form class="form" data-id="transport" role="form" method="post">
  74. <div class="mb-2">
  75. <label for="transport_destination">{{ lang.admin.destination }}</label>
  76. <input class="form-control" id="transport_destination" name="destination" placeholder='{{ lang.admin.transport_dest_format }}' required>
  77. </div>
  78. <div class="mb-2">
  79. <label for="transport_nexthop">{{ lang.admin.nexthop }}</label>
  80. <input class="form-control" id="transport_nexthop" name="nexthop" placeholder='host:25, host, [host]:25, [0.0.0.0]:25' required>
  81. </div>
  82. <div class="mb-2">
  83. <label for="transport_username">{{ lang.admin.username }}</label>
  84. <input class="form-control" id="transport_username" name="username">
  85. </div>
  86. <div class="mb-4">
  87. <label for="transport_password">{{ lang.admin.password }}</label>
  88. <input class="form-control" id="transport_password" name="password" type="password">
  89. </div>
  90. <div class="mb-2">
  91. <label>
  92. <input type="checkbox" class="form-check-input" name="is_mx_based" value="1"> {{ lang.admin.lookup_mx|raw }}
  93. </label>
  94. </div>
  95. <div class="mb-4">
  96. <label>
  97. <input type="checkbox" class="form-check-input" name="active" value="1"> {{ lang.admin.active }}
  98. </label>
  99. </div>
  100. <p class="text-muted">{{ lang.admin.credentials_transport_warning|raw }}</p>
  101. <button class="btn btn-sm d-block d-sm-inline btn-success" data-action="add_item" data-id="transport" data-api-url='add/transport' data-api-attr='{}' href="#"><i class="bi bi-plus-lg"></i> {{ lang.admin.add }}</button>
  102. </form>
  103. </div>
  104. </div>
  105. </div>
  106. </div>
  107. </div>