Files
PyMTA-server/email_frontend/templates/add_domain.html
2025-06-07 10:48:03 +01:00

113 lines
4.6 KiB
HTML

{% extends "base.html" %}
{% block title %}Add Domain - Email Server Management{% endblock %}
{% block page_title %}Add New Domain{% endblock %}
{% block content %}
<div class="row justify-content-center">
<div class="col-lg-6">
<div class="card">
<div class="card-header">
<h5 class="mb-0">
<i class="bi bi-plus-circle me-2"></i>
Add New Domain
</h5>
</div>
<div class="card-body">
<form method="post">
<div class="mb-3">
<label for="domain_name" class="form-label">
<i class="bi bi-globe me-1"></i>
Domain Name
</label>
<input type="text"
class="form-control"
id="domain_name"
name="domain_name"
placeholder="example.com"
required
pattern="^[a-zA-Z0-9][a-zA-Z0-9-]*[a-zA-Z0-9]*\.?[a-zA-Z]{2,}$">
<div class="form-text">
Enter the domain name that will be used for sending emails (e.g., example.com)
</div>
</div>
<div class="alert alert-info">
<h6 class="alert-heading">
<i class="bi bi-info-circle me-2"></i>
What happens next?
</h6>
<ul class="mb-0">
<li>Domain will be added to the system</li>
<li>DKIM key pair will be automatically generated</li>
<li>You'll need to configure DNS records</li>
<li>Add users or whitelist IPs for authentication</li>
</ul>
</div>
<div class="d-flex justify-content-between">
<a href="{{ url_for('email.domains_list') }}" class="btn btn-secondary">
<i class="bi bi-arrow-left me-2"></i>
Back to Domains
</a>
<button type="submit" class="btn btn-primary">
<i class="bi bi-plus-circle me-2"></i>
Add Domain
</button>
</div>
</form>
</div>
</div>
<div class="card mt-4">
<div class="card-header">
<h6 class="mb-0">
<i class="bi bi-question-circle me-2"></i>
Domain Requirements
</h6>
</div>
<div class="card-body">
<div class="row">
<div class="col-md-6">
<h6 class="text-success">
<i class="bi bi-check-circle me-1"></i>
Valid Examples
</h6>
<ul class="list-unstyled">
<li><code>example.com</code></li>
<li><code>mail.example.com</code></li>
<li><code>my-domain.org</code></li>
<li><code>company.co.uk</code></li>
</ul>
</div>
<div class="col-md-6">
<h6 class="text-danger">
<i class="bi bi-x-circle me-1"></i>
Invalid Examples
</h6>
<ul class="list-unstyled">
<li><code>http://example.com</code></li>
<li><code>example</code></li>
<li><code>.example.com</code></li>
<li><code>example..com</code></li>
</ul>
</div>
</div>
</div>
</div>
</div>
</div>
{% endblock %}
{% block extra_js %}
<script>
document.getElementById('domain_name').addEventListener('input', function(e) {
// Convert to lowercase and remove protocol if present
let value = e.target.value.toLowerCase();
value = value.replace(/^https?:\/\//, '');
value = value.replace(/\/$/, '');
e.target.value = value;
});
</script>
{% endblock %}