form.ejs 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. <div class="modal-content">
  2. <div class="modal-header">
  3. <h5 class="modal-title"><%- i18n('access-lists', 'form-title', {id: id}) %></h5>
  4. <button type="button" class="close cancel" aria-label="Close" data-dismiss="modal">&nbsp;</button>
  5. </div>
  6. <div class="modal-body has-tabs">
  7. <form>
  8. <ul class="nav nav-tabs" role="tablist">
  9. <li role="presentation" class="nav-item"><a href="#details" aria-controls="tab1" role="tab" data-toggle="tab" class="nav-link active show" aria-selected="true"><i class="fe fe-zap"></i> <%- i18n('access-lists', 'details') %></a></li>
  10. <li role="presentation" class="nav-item"><a href="#auth" aria-controls="tab4" role="tab" data-toggle="tab" class="nav-link" aria-selected="false"><i class="fe fe-users"></i> <%- i18n('access-lists', 'authorization') %></a></li>
  11. <li role="presentation" class="nav-item"><a href="#access" aria-controls="tab2" role="tab" data-toggle="tab" class="nav-link" aria-selected="false"><i class="fe fe-radio"></i> <%- i18n('access-lists', 'access') %></a></li>
  12. </ul>
  13. <div class="tab-content">
  14. <!-- Details -->
  15. <div role="tabpanel" class="tab-pane active show" id="details">
  16. <div class="row">
  17. <div class="col-sm-12 col-md-12">
  18. <div class="form-group">
  19. <label class="form-label"><%- i18n('str', 'name') %> <span class="form-required">*</span></label>
  20. <input type="text" name="name" class="form-control" value="<%- name %>" required>
  21. </div>
  22. </div>
  23. <div class="col-sm-6 col-md-6">
  24. <div class="form-group">
  25. <label class="custom-switch">
  26. <input type="checkbox" class="custom-switch-input" name="satisfy_any" value="1"<%- typeof satisfy_any !== 'undefined' && satisfy_any ? ' checked' : '' %>>
  27. <span class="custom-switch-indicator"></span>
  28. <span class="custom-switch-description"><%- i18n('access-lists', 'satisfy-any') %></span>
  29. </label>
  30. </div>
  31. </div>
  32. <div class="col-sm-6 col-md-6">
  33. <div class="form-group">
  34. <label class="custom-switch">
  35. <input type="checkbox" class="custom-switch-input" name="pass_auth" value="1"<%- typeof pass_auth !== 'undefined' && pass_auth ? ' checked' : '' %>>
  36. <span class="custom-switch-indicator"></span>
  37. <span class="custom-switch-description"><%- i18n('access-lists', 'pass-auth') %></span>
  38. </label>
  39. </div>
  40. </div>
  41. </div>
  42. </div>
  43. <!-- Authorization -->
  44. <div class="tab-pane" id="auth">
  45. <p>
  46. Basic Authorization via
  47. <a target="_blank" href="https://nginx.org/en/docs/http/ngx_http_auth_basic_module.html">
  48. Nginx HTTP Basic Authentication
  49. </a>
  50. </p>
  51. <div class="row">
  52. <div class="col-sm-6 col-md-6">
  53. <div class="form-group">
  54. <label class="form-label"><%- i18n('str', 'username') %></label>
  55. </div>
  56. </div>
  57. <div class="col-sm-6 col-md-6">
  58. <div class="form-group">
  59. <label class="form-label"><%- i18n('str', 'password') %></label>
  60. </div>
  61. </div>
  62. </div>
  63. <div class="items"><!-- items --></div>
  64. <div class="btn-list justify-content-end">
  65. <button type="button" class="btn btn-teal auth_add"><%- i18n('access-lists', 'auth-add') %></button>
  66. </div>
  67. </div>
  68. <!-- Access -->
  69. <div class="tab-pane" id="access">
  70. <p>
  71. IP Address Whitelist/Blacklist via
  72. <a target="_blank" href="https://nginx.org/en/docs/http/ngx_http_access_module.html">
  73. Nginx HTTP Access
  74. </a>
  75. </p>
  76. <div class="clients"><!-- clients --></div>
  77. <div class="row">
  78. <div class="col-sm-3 col-md-3">
  79. <div class="form-group">
  80. <input type="text" class="form-control disabled" value="deny" disabled>
  81. </div>
  82. </div>
  83. <div class="col-sm-9 col-md-9">
  84. <div class="form-group">
  85. <input type="text" class="form-control disabled" value="all" disabled>
  86. </div>
  87. </div>
  88. </div>
  89. <div class="text-muted">Note that the <code>allow</code> and <code>deny</code> directives will be applied in the order they are defined.</div>
  90. <div class="btn-list justify-content-end">
  91. <button type="button" class="btn btn-teal access_add"><%- i18n('access-lists', 'access-add') %></button>
  92. </div>
  93. </div>
  94. </div>
  95. </form>
  96. </div>
  97. <div class="modal-footer">
  98. <button type="button" class="btn btn-secondary cancel" data-dismiss="modal"><%- i18n('str', 'cancel') %></button>
  99. <button type="button" class="btn btn-teal save"><%- i18n('str', 'save') %></button>
  100. </div>
  101. </div>