refactor(ui): заменить стандартные формы на кастомные html элементы
- Заменены стандартные формы Django на кастомные HTML элементы для полей: название, описание, категории, теги и цена со скидкой - Добавлена валидация и стилизация для каждого поля - Улучшена структура и читаемость кода шаблона
This commit is contained in:
@@ -26,8 +26,13 @@
|
||||
{% csrf_token %}
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="id_name" class="form-label">Название *</label>
|
||||
{{ form.name }}
|
||||
<label for="{{ form.name.id_for_label }}" class="form-label">Название *</label>
|
||||
<input type="text"
|
||||
name="{{ form.name.html_name }}"
|
||||
class="form-control{% if form.name.errors %} is-invalid{% endif %}"
|
||||
id="{{ form.name.id_for_label }}"
|
||||
value="{{ form.name.value|default:'' }}"
|
||||
required>
|
||||
{% if form.name.errors %}
|
||||
<div class="invalid-feedback d-block">
|
||||
{{ form.name.errors }}
|
||||
@@ -36,8 +41,11 @@
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="id_description" class="form-label">Описание</label>
|
||||
{{ form.description }}
|
||||
<label for="{{ form.description.id_for_label }}" class="form-label">Описание</label>
|
||||
<textarea name="{{ form.description.html_name }}"
|
||||
class="form-control{% if form.description.errors %} is-invalid{% endif %}"
|
||||
id="{{ form.description.id_for_label }}"
|
||||
rows="3">{{ form.description.value|default:'' }}</textarea>
|
||||
{% if form.description.errors %}
|
||||
<div class="invalid-feedback d-block">
|
||||
{{ form.description.errors }}
|
||||
@@ -46,8 +54,18 @@
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="id_categories" class="form-label">Категории</label>
|
||||
{{ form.categories }}
|
||||
<label for="{{ form.categories.id_for_label }}" class="form-label">Категории</label>
|
||||
<select name="{{ form.categories.html_name }}"
|
||||
class="form-select{% if form.categories.errors %} is-invalid{% endif %}"
|
||||
id="{{ form.categories.id_for_label }}"
|
||||
multiple>
|
||||
{% for value, label in form.categories.field.choices %}
|
||||
<option value="{{ value }}"
|
||||
{% if value in form.categories.value %}selected{% endif %}>
|
||||
{{ label }}
|
||||
</option>
|
||||
{% endfor %}
|
||||
</select>
|
||||
{% if form.categories.errors %}
|
||||
<div class="invalid-feedback d-block">
|
||||
{{ form.categories.errors }}
|
||||
@@ -59,8 +77,18 @@
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="id_tags" class="form-label">Теги</label>
|
||||
{{ form.tags }}
|
||||
<label for="{{ form.tags.id_for_label }}" class="form-label">Теги</label>
|
||||
<select name="{{ form.tags.html_name }}"
|
||||
class="form-select{% if form.tags.errors %} is-invalid{% endif %}"
|
||||
id="{{ form.tags.id_for_label }}"
|
||||
multiple>
|
||||
{% for value, label in form.tags.field.choices %}
|
||||
<option value="{{ value }}"
|
||||
{% if value in form.tags.value %}selected{% endif %}>
|
||||
{{ label }}
|
||||
</option>
|
||||
{% endfor %}
|
||||
</select>
|
||||
{% if form.tags.errors %}
|
||||
<div class="invalid-feedback d-block">
|
||||
{{ form.tags.errors }}
|
||||
@@ -69,8 +97,14 @@
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="id_sale_price" class="form-label">Цена со скидкой</label>
|
||||
{{ form.sale_price }}
|
||||
<label for="{{ form.sale_price.id_for_label }}" class="form-label">Цена со скидкой</label>
|
||||
<input type="number"
|
||||
name="{{ form.sale_price.html_name }}"
|
||||
class="form-control{% if form.sale_price.errors %} is-invalid{% endif %}"
|
||||
id="{{ form.sale_price.id_for_label }}"
|
||||
value="{{ form.sale_price.value|default:'' }}"
|
||||
step="0.01"
|
||||
min="0">
|
||||
{% if form.sale_price.errors %}
|
||||
<div class="invalid-feedback d-block">
|
||||
{{ form.sale_price.errors }}
|
||||
|
||||
Reference in New Issue
Block a user