fix form new route
This commit is contained in:
SDE
2023-07-28 19:07:36 +03:00
parent 45234121d4
commit c0ed5d5803
4 changed files with 259 additions and 177 deletions

View File

@@ -19,10 +19,19 @@ def new_route_view_ajax(request):
if request.method != 'POST': if request.method != 'POST':
raise Http404 raise Http404
data = request.POST
form = CreateRouteForm(data)
if not form.is_valid():
pass
Dict = { Dict = {
'form': CreateRouteForm() 'form': form
} }
# print(form)
html = render_to_string('blocks/profile/b_new_route.html', Dict, request=request) html = render_to_string('blocks/profile/b_new_route.html', Dict, request=request)
return JsonResponse({'html': html}, status=200) return JsonResponse({'html': html}, status=200)

View File

@@ -3,10 +3,11 @@ from django.utils.translation import gettext_lazy as _
from BaseModels.base_models import BaseModel from BaseModels.base_models import BaseModel
type_transport_choices = ( type_transport_choices = [
('', _('-- Выберите cпособ перевозки --')),
('avia', _('Авиатранспорт')), ('avia', _('Авиатранспорт')),
('road', _('Наземный транспорт')) ('road', _('Наземный транспорт'))
) ]
transfer_location_choices = ( transfer_location_choices = (
('airport', _('В аэропорту')), ('airport', _('В аэропорту')),
@@ -35,7 +36,7 @@ class Route(BaseModel):
choices=owner_type_choices, default='customer', verbose_name=_('Тип опреации')) choices=owner_type_choices, default='customer', verbose_name=_('Тип опреации'))
type_transport = models.CharField( type_transport = models.CharField(
choices=type_transport_choices, default='avia', verbose_name=_('Выберите способ перевозки')) choices=type_transport_choices, default='', verbose_name=_('Выберите способ перевозки'))
departure_DT = models.DateTimeField(default=True, verbose_name=_('Дата и время выезда')) departure_DT = models.DateTimeField(default=True, verbose_name=_('Дата и время выезда'))
arrival_DT = models.DateTimeField(default=True, verbose_name=_('Дата и время прибытия')) arrival_DT = models.DateTimeField(default=True, verbose_name=_('Дата и время прибытия'))
from_address_point = models.IntegerField(verbose_name=_('Пункт выезда')) from_address_point = models.IntegerField(verbose_name=_('Пункт выезда'))

View File

@@ -42,10 +42,13 @@ function sendRoute(el){
//cleaning route inputs after selection changes //cleaning route inputs after selection changes
function OnSelectionChange(el) { function OnSelectionChange(el) {
event.preventDefault()
let form = el.form; let form = el.form;
let formData = new FormData(form); let formData = new FormData(form);
$.ajax({ $.ajax({
headers: { "X-CSRFToken": $('input[name=csrfmiddlewaretoken]').val() }, headers: {"X-CSRFToken": $('input[name=csrfmiddlewaretoken]').val()},
url: '/ru/user_account/new_route_view/', url: '/ru/user_account/new_route_view/',
type: "POST", type: "POST",
// async: true, // async: true,
@@ -54,24 +57,22 @@ function OnSelectionChange(el) {
contentType: false, contentType: false,
// enctype: 'json', // enctype: 'json',
data: formData, data: formData,
success: function(data){ success: function (data) {
// console.log('data received') console.log('data.html');
// location.href = '/profile' // location.href = '/profile'
document.querySelector(".info_profile").innerHTML = data.html document.querySelector(".info_profile").innerHTML = data.html
//
$(document).ready(function (e){ // $(document).ready(function (e){
$('#id_weight').ionRangeSlider({ // $('#id_weight').ionRangeSlider({
skin: "round", // skin: "round",
type: "single", // type: "single",
min: 0, // min: 0,
max: 1000, // max: 1000,
from: 100, // from: 100,
step: 1, // step: 1,
grid: true, // grid: true,
grid_num: 5, // grid_num: 5,
}); // }
});
//get dynamic value //get dynamic value
// let fromCountry = document.getElementById('id_from_country'); // let fromCountry = document.getElementById('id_from_country');

View File

@@ -9,14 +9,18 @@
<label for="id_type_transport">{{ form.fields.type_transport.label }}</label> <label for="id_type_transport">{{ form.fields.type_transport.label }}</label>
</div> </div>
<div> <div>
<select <select
onchange="OnSelectionChange(this)" onchange="OnSelectionChange(this)"
name="type_transport" name="type_transport"
id="id_type_transport"> id="id_type_transport">
{% for item in form.fields.type_transport.choices %} {% for item in form.fields.type_transport.choices %}
<option <option
value="{{ item.0 }}"{% if form.cleaned_data.type_transport == item.0 %} value="{{ item.0 }}"
selected="selected"{% endif %}>{{ item.1 }} {% if form.cleaned_data.type_transport == item.0 %}
selected="selected"
{% endif %}>
{{ item.1 }}
</option> </option>
{% endfor %} {% endfor %}
</select> </select>
@@ -25,8 +29,9 @@
{% endif %} {% endif %}
</div> </div>
<hr> {% if form.cleaned_data and form.cleaned_data.type_transport and form.cleaned_data.type_transport != '' %}
<div class="departure_arrival"> <hr>
<div class="departure_arrival">
<div> <div>
<label for="id_departure_DT">{{ form.fields.departure_DT.label }}</label> <label for="id_departure_DT">{{ form.fields.departure_DT.label }}</label>
@@ -50,6 +55,58 @@
{% if form.fields.arrival_DT.required %} required{% endif %} {% if form.fields.arrival_DT.required %} required{% endif %}
id="id_arrival_DT" id="id_arrival_DT"
{% if form.data.arrival_DT %}value="{{ form.data.arrival_DT }}"{% endif %} {% if form.data.arrival_DT %}value="{{ form.data.arrival_DT }}"{% endif %}
{# |date: 'Y-m-d H:i' #}
/>
{% if form.errors and form.errors.arrival_DT %}
<span>{{ form.errors.arrival_DT }}</span>
{% endif %}
</div>
</div>
<hr>
<div class="from_to_country">
<div class="from_country_container">
<label for="id_from_address_point">{{ form.fields.from_address_point.label }}</label>
<input type="number" name="from_address_point" id="id_from_address_point" hidden />
<input
oninput="searchTown(this)"
onclick="searchTown(this)"
onblur="onblurInputField(event, this)"
type="text"
name="from_address_point_txt"
{% if form.fields.from_address_point.required %} required{% endif %}
id="id_from_address_point_txt"
{% if form.cleaned_data.from_address_point_txt %}value="{{ form.cleaned_data.from_address_point_txt }}"{% endif %}
/>
<div class="input_list" name="from_address_point_txt_list">
</div>
{% if form.errors and form.errors.from_address_point %}
<span>{{ form.errors.from_address_point}}</span>
{% endif %}
</div>
<div>
<label for="id_to_address_point">{{ form.fields.to_address_point.label }}</label>
<input type="number" name="to_address_point" id="id_to_address_point" hidden />
<input
oninput="searchTown(this)"
onclick="searchTown(this)"
onblur="onblurInputField(event, this)"
type="text"
name="to_address_point_txt"
{% if form.fields.to_address_point.required %} required{% endif %}
id="id_to_address_point_txt"
{% if form.cleaned_data.to_address_point_txt %}value="{{ form.cleaned_data.to_address_point_txt}}"{% endif %}
{% if form.errors and form.errors.departure_DT %}
<span>{{ form.errors.departure_DT }}</span>
{% endif %}
</div>
<div>
<label for="id_arrival_DT">{{ form.fields.arrival_DT.label }}</label>
<input
type="datetime-local"
name="arrival_DT"
{% if form.fields.arrival_DT.required %} required{% endif %}
id="id_arrival_DT"
{% if form.data.arrival_DT %}value="{{ form.data.arrival_DT }}"{% endif %}
{# |date: 'Y-m-d H:i' #} {# |date: 'Y-m-d H:i' #}
/> />
{% if form.errors and form.errors.arrival_DT %} {% if form.errors and form.errors.arrival_DT %}
@@ -100,14 +157,14 @@
{% endif %} {% endif %}
</div> </div>
</div> </div>
{# <div>#} {# <div>#}
{# <label for="id_from_city">{{ form.fields.from_city.label }}</label>#} {# <label for="id_from_city">{{ form.fields.from_city.label }}</label>#}
{# <input type="text" name="from_city"{% if form.fields.from_city.required %} required{% endif %} id="id_from_city">#} {# <input type="text" name="from_city"{% if form.fields.from_city.required %} required{% endif %} id="id_from_city">#}
{# </div>#} {# </div>#}
{# <div>#} {# <div>#}
{# <label for="id_to_city">{{ form.fields.to_city.label }}</label>#} {# <label for="id_to_city">{{ form.fields.to_city.label }}</label>#}
{# <input type="text" name="to_city"{% if form.fields.to_city.required %} required{% endif %} id="id_to_city">#} {# <input type="text" name="to_city"{% if form.fields.to_city.required %} required{% endif %} id="id_to_city">#}
{# </div>#} {# </div>#}
<div class="from_to_place"> <div class="from_to_place">
<div> <div>
<label for="id_from_place">{{ form.fields.from_place.label }}</label> <label for="id_from_place">{{ form.fields.from_place.label }}</label>
@@ -145,29 +202,40 @@
</div> </div>
</div> </div>
<hr> <hr>
<div> <div>
<label for="id_cargo_type">{{ form.fields.cargo_type.label }}</label> <label for="id_cargo_type">{{ form.fields.cargo_type.label }}</label>
</div> </div>
{#<div>#} {#<div>#}
{# <select#} {# <select#}
{# multiple#} {# multiple#}
{# size="5"#} {# size="5"#}
{# name="cargo_type"#} {# name="cargo_type"#}
{# id="id_cargo_type"#} {# id="id_cargo_type"#}
{# {% if form.fields.cargo_type.required %} required{% endif %}>#} {# {% if form.fields.cargo_type.required %} required{% endif %}>#}
{# {% for item in form.fields.cargo_type.choices %}#} {# {% for item in form.fields.cargo_type.choices %}#}
{# <option#} {# <option#}
{# value="{{ item.0 }}"{% if form.fields.cargo_type == item.0 %}#} {# value="{{ item.0 }}"{% if form.fields.cargo_type == item.0 %}#}
{# selected="selected"{% endif %}>{{ item.1 }}#} {# selected="selected"{% endif %}>{{ item.1 }}#}
{# </option>#} {# </option>#}
{# {% endfor %}#} {# {% endfor %}#}
{##} {##}
{# </select>#} {# </select>#}
{# </div>#} {# </div>#}
<div>
{% for item in form.fields.cargo_type.choices %}
<input
type="checkbox"
name="cargo_type"
id="id_cargo_type"
{% if form.fields.cargo_type.required %} required{% endif %}
value="{{ item.0 }}"
{% if form.fields.cargo_type == item.0 %}
{% endif %}/>{{ item.1 }}
{% endfor %}
<div class="checkbox_cargo_type"> <div class="checkbox_cargo_type">
{% for item in form.fields.cargo_type.choices %} {% for item in form.fields.cargo_type.choices %}
<input <input
@@ -180,16 +248,16 @@
{% endif %}/>{{ item.1 }} {% endif %}/>{{ item.1 }}
{% endfor %} {% endfor %}
{# <lable for="">#} {# <lable for="">#}
{##} {##}
{# </lable>#} {# </lable>#}
{% if form.errors and form.errors.cargo_type %} {% if form.errors and form.errors.cargo_type %}
<span>{{ form.errors.cargo_type }}</span> <span>{{ form.errors.cargo_type }}</span>
{% endif %} {% endif %}
</div> </div>
<hr> <hr>
<div class="range-slider"> <div class="range-slider">
<label for="id_weight">{{ form.fields.weight.label }}</label> <label for="id_weight">{{ form.fields.weight.label }}</label>
@@ -198,7 +266,7 @@
id="id_weight" id="id_weight"
{% if form.fields.weight.required %} required{% endif %} {% if form.fields.weight.required %} required{% endif %}
name="weight" name="weight"
{# value=""#} {# value=""#}
{% if form.cleaned_data.weight %}value="{{ form.cleaned_data.weight}}"{% endif %} {% if form.cleaned_data.weight %}value="{{ form.cleaned_data.weight}}"{% endif %}
/> />
{% if form.errors and form.errors.weight %} {% if form.errors and form.errors.weight %}
@@ -206,9 +274,9 @@
{% endif %} {% endif %}
</div> </div>
<hr> <hr>
<div class="phone"> <div class="phone">
<div> <div>
<label for="id_phone">{{ form.fields.phone.label }}</label> <label for="id_phone">{{ form.fields.phone.label }}</label>
<input <input
@@ -239,9 +307,9 @@
<span>{{ form.errors.extra_phone }}</span> <span>{{ form.errors.extra_phone }}</span>
{% endif %} {% endif %}
</div> </div>
</div> </div>
<hr> <hr>
<div> <div>
<label for="id_receive_msg_by_email">{{ form.fields.receive_msg_by_email.label }}</label> <label for="id_receive_msg_by_email">{{ form.fields.receive_msg_by_email.label }}</label>
@@ -254,4 +322,7 @@
<button id="registration" onclick="sendRoute(this)"> Разместить объявления </button> <button id="registration" onclick="sendRoute(this)"> Разместить объявления </button>
</div> </div>
{% endif %}
</form> </form>