mirror of
https://github.com/cwinfo/powerdns-admin.git
synced 2025-01-09 03:45:39 +00:00
c00ddea2fc
Added server-side logic for register.html validation Keep form firelds on register.html in the event of wrong input fields to save users from retyping info More button rounding
183 lines
8.3 KiB
HTML
183 lines
8.3 KiB
HTML
{% extends "base.html" %}
|
|
|
|
{% set active_page = "admin_accounts" %}
|
|
|
|
{% block title %}
|
|
<title>
|
|
Edit Account - {{ SITE_NAME }}
|
|
</title>
|
|
{% endblock %}
|
|
|
|
{% block dashboard_stat %}
|
|
<div class="content-header">
|
|
<div class="container-fluid">
|
|
<div class="row mb-2">
|
|
<div class="col-sm-6">
|
|
<h1 class="m-0 text-dark">
|
|
Account
|
|
<small>{% if create %}New account{% else %}{{ account.name }}{% endif %}</small>
|
|
</h1>
|
|
</div>
|
|
<div class="col-sm-6">
|
|
<ol class="breadcrumb float-sm-right">
|
|
<li class="breadcrumb-item"><a href="{{ url_for('dashboard.dashboard') }}">Home</a></li>
|
|
<li class="breadcrumb-item"><a href="{{ url_for('admin.manage_account') }}">Accounts</a></li>
|
|
<li class="breadcrumb-item active">{% if create %}Add{% else %}Edit{% endif %} account</li>
|
|
</ol>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endblock %}
|
|
|
|
{% block content %}
|
|
<section class="content">
|
|
<div class="container-fluid">
|
|
<div class="row">
|
|
<div class="col-4">
|
|
<div class="card shadow">
|
|
<div class="card-header with-border">
|
|
<h3 class="card-title">{% if create %}Add{% else %}Edit{% endif %} account</h3>
|
|
</div>
|
|
<form role="form" method="post" action="{% if create %}{{ url_for('admin.edit_account') }}{% else %}{{ url_for('admin.edit_account', account_name=account.name) }}{% endif %}">
|
|
<input type="hidden" name="_csrf_token" value="{{ csrf_token() }}">
|
|
<input type="hidden" name="create" value="{{ create }}">
|
|
<div class="card-body">
|
|
{% if error %}
|
|
<div class="alert alert-danger alert-dismissible">
|
|
<button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>
|
|
<h4><i class="icon fa fa-ban"></i> Error!</h4>
|
|
{{ error }}
|
|
</div>
|
|
<span class="help-block">{{ error }}</span>
|
|
{% endif %}
|
|
<div class="form-group has-feedback {% if invalid_accountname or duplicate_accountname %}has-error{% endif %}">
|
|
<label class="control-label" for="accountname">Name</label>
|
|
<input type="text" class="form-control" placeholder="Account Name (required)"
|
|
name="accountname" {% if account %}value="{{ account.name }}" {% endif %}
|
|
{% if not create %}disabled{% endif %}>
|
|
<span class="fa fa-cog form-control-feedback"></span>
|
|
{% if invalid_accountname %}
|
|
<span class="help-block">Cannot be blank and must only contain alphanumeric
|
|
characters{% if SETTING.get('account_name_extra_chars') %}, dots, hyphens or underscores{% endif %}.
|
|
</span>
|
|
{% elif duplicate_accountname %}
|
|
<span class="help-block">Account name already in use.</span>
|
|
{% endif %}
|
|
</div>
|
|
<div class="form-group has-feedback">
|
|
<label class="control-label" for="accountdescription">Description</label>
|
|
<input type="text" class="form-control" placeholder="Account Description (optional)"
|
|
name="accountdescription" {% if account %}value="{{ account.description }}" {% endif %}>
|
|
<span class="fa fa-industry form-control-feedback"></span>
|
|
</div>
|
|
<div class="form-group has-feedback">
|
|
<label class="control-label" for="accountcontact">Contact Person</label>
|
|
<input type="text" class="form-control" placeholder="Contact Person (optional)"
|
|
name="accountcontact" {% if account %}value="{{ account.contact }}" {% endif %}>
|
|
<span class="fa fa-user form-control-feedback"></span>
|
|
</div>
|
|
<div class="form-group has-feedback">
|
|
<label class="control-label" for="accountmail">Mail Address</label>
|
|
<input type="email" class="form-control" placeholder="Mail Address (optional)"
|
|
name="accountmail" {% if account %}value="{{ account.mail }}" {% endif %}>
|
|
<span class="fa fa-envelope form-control-feedback"></span>
|
|
</div>
|
|
</div>
|
|
<div class="card-header with-border">
|
|
<h3 class="card-title">Access Control</h3>
|
|
</div>
|
|
<div class="card-body">
|
|
<p>Users on the right have access to manage records in all domains
|
|
associated with the account.
|
|
</p>
|
|
<p>Click on users to move between columns.</p>
|
|
<div class="form-group col-2">
|
|
<select multiple="multiple" class="form-control" id="account_multi_user"
|
|
name="account_multi_user">
|
|
{% for user in users %}
|
|
<option {% if user.id in account_user_ids|default([]) %}selected{% endif %}
|
|
value="{{ user.username }}">{{ user.username }}
|
|
</option>
|
|
{% endfor %}
|
|
</select>
|
|
</div>
|
|
</div>
|
|
<div class="card-footer">
|
|
<button type="submit"
|
|
class="btn btn-flat btn-primary">{% if create %}Create{% else %}Update{% endif %}
|
|
Account
|
|
</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
<div class="col-8">
|
|
<div class="card shadow">
|
|
<div class="card-header with-border">
|
|
<h3 class="card-title">Help with creating a new account</h3>
|
|
</div>
|
|
<div class="card-body">
|
|
<p>
|
|
An account allows grouping of domains belonging to a particular entity, such as a customer or
|
|
department.
|
|
<br />
|
|
A domain can be assigned to an account upon domain creation or through the domain administration
|
|
page.
|
|
</p>
|
|
<p>Fill in all the fields to the in the form to the left.</p>
|
|
<p>
|
|
<strong>Name</strong> is an account identifier. It will be lowercased and can contain alphanumeric
|
|
characters{% if SETTING.get('account_name_extra_chars') %}, dots, hyphens and underscores (no space or other special character is allowed)
|
|
{% else %} (no extra character is allowed){% endif %}.<br />
|
|
<strong>Description</strong> is a user friendly name for this account.<br />
|
|
<strong>Contact person</strong> is the name of a contact person at the account.<br />
|
|
<strong>Mail Address</strong> is an e-mail address for the contact person.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
{% endblock %}
|
|
{% block extrascripts %}
|
|
<script>
|
|
$("#account_multi_user").multiSelect({
|
|
selectableHeader: "<input type='text' class='search-input' autocomplete='off' placeholder='Username'>",
|
|
selectionHeader: "<input type='text' class='search-input' autocomplete='off' placeholder='Username'>",
|
|
afterInit: function (ms) {
|
|
var that = this,
|
|
$selectableSearch = that.$selectableUl.prev(),
|
|
$selectionSearch = that.$selectionUl.prev(),
|
|
selectableSearchString = '#' + that.$container.attr('id') + ' .ms-elem-selectable:not(.ms-selected)',
|
|
selectionSearchString = '#' + that.$container.attr('id') + ' .ms-elem-selection.ms-selected';
|
|
|
|
that.qs1 = $selectableSearch.quicksearch(selectableSearchString)
|
|
.on('keydown', function (e) {
|
|
if (e.which === 40) {
|
|
that.$selectableUl.focus();
|
|
return false;
|
|
}
|
|
});
|
|
|
|
that.qs2 = $selectionSearch.quicksearch(selectionSearchString)
|
|
.on('keydown', function (e) {
|
|
if (e.which == 40) {
|
|
that.$selectionUl.focus();
|
|
return false;
|
|
}
|
|
});
|
|
},
|
|
afterSelect: function () {
|
|
this.qs1.cache();
|
|
this.qs2.cache();
|
|
},
|
|
afterDeselect: function () {
|
|
this.qs1.cache();
|
|
this.qs2.cache();
|
|
}
|
|
});
|
|
</script>
|
|
{% endblock %}
|