first commit
This commit is contained in:
Binary file not shown.
@@ -18,17 +18,6 @@ def authorize_google():
|
||||
client = gspread.authorize(creds)
|
||||
return client
|
||||
|
||||
# Функция проверки существования пользователя в таблице
|
||||
def user_exists(sheet, fio, tel, user_id):
|
||||
records = sheet.get_all_values() # Получаем все данные таблицы без заголовков
|
||||
|
||||
for row in records[1:]: # Пропускаем первую строку, если там заголовки, или уберите [1:], если заголовков нет
|
||||
if len(row) > 1 and row[0] == fio and row[1] == tel:# and row[13] == user_id:
|
||||
return True, 'Ваши данные уже присутствуют в таблице' # Если ФИО, телефон и user_id совпадают, значит, запись уже существует
|
||||
if row[13] == user_id:
|
||||
return True, 'C данного Telegram аккаунта уже проведена регистрация'
|
||||
return False, 'Ок'
|
||||
|
||||
|
||||
# Обработка формы
|
||||
@webApp.route('/form_submit', methods=['POST'])
|
||||
@@ -38,26 +27,12 @@ def form_submit():
|
||||
data['current_time'] = datetime.datetime.now().strftime("%d.%m.%Y, %H:%M")
|
||||
|
||||
# Авторизация и добавление данных в Google Sheets
|
||||
sheet = authorize_google().open("Информация о сотрудниках").sheet1
|
||||
sheet = authorize_google().open("Пациенты клиники").sheet1
|
||||
|
||||
# Проверка, существует ли уже пользователь
|
||||
exists_flag, message = user_exists(sheet, data['fio'], data['tel'], data['user_id'])
|
||||
if exists_flag:
|
||||
return jsonify({'success': False, 'error': message})
|
||||
|
||||
sheet.append_row([
|
||||
data['fio'],
|
||||
data['tel'],
|
||||
data['email'],
|
||||
data['passport'][:5],
|
||||
data['passport'][5:],
|
||||
data['passport_issued_by'],
|
||||
data['passport_date'],
|
||||
data['postal_code'],
|
||||
data['address'],
|
||||
data['residential_address'],
|
||||
data['snils'],
|
||||
data['inn'],
|
||||
data['dob'],
|
||||
data['user_id'], # Записываем Telegram ID пользователя
|
||||
data['current_time'] # Записываем время отправки данных
|
||||
|
||||
@@ -23,7 +23,7 @@ script(type="text/javascript", src="/js/2.0.dashboard.js?q="~randomString())
|
||||
|
||||
|
||||
.my-3.mx-4.success-field
|
||||
label.form-label.m-0(for="fio")='Фамилия Имя Отчество полностью'
|
||||
label.form-label.m-0(for="fio")='Укажите ФИО пациента строго в формате “Фамилия Имя Отчество”. Если пациентом является Ваш ребенок, введите только ФИО ребенка.'
|
||||
input.form-control.tg_input#fio
|
||||
small="(Пожалуйста, проверьте формат ввода)"
|
||||
.my-3.mx-4.success-field
|
||||
@@ -36,45 +36,13 @@ script(type="text/javascript", src="/js/2.0.dashboard.js?q="~randomString())
|
||||
span.x-icn
|
||||
small="(Пожалуйста, проверьте формат ввода)"
|
||||
.my-3.mx-4.success-field
|
||||
label.form-label.m-0(for="dob")='Дата рождения'
|
||||
input.form-control.tg_input#dob(type="date")
|
||||
label.form-label.m-0(for="dob")='Укажите год рождения пациента в формате YYYY. Если пациентом является Ваш ребенок, введите только год рождения ребенка в формате YYYY.'
|
||||
input.form-control.tg_input#dob
|
||||
small="(Пожалуйста, проверьте формат ввода)"
|
||||
.my-3.mx-4.success-field
|
||||
label.form-label.m-0(for="email")='Электронная почта'
|
||||
input.form-control.tg_input#email
|
||||
small="(Пожалуйста, проверьте формат ввода)"
|
||||
.my-3.mx-4.success-field
|
||||
label.form-label.m-0(for="passport")='Серия и номер паспорта'
|
||||
input.form-control.tg_input#passport
|
||||
small="(Пожалуйста, проверьте формат ввода)"
|
||||
.my-3.mx-4.success-field
|
||||
label.form-label.m-0(for="passport_date")='Дата выдачи паспорта'
|
||||
input.form-control.tg_input#passport_date(type="date")
|
||||
small="(Пожалуйста, проверьте формат ввода)"
|
||||
.my-3.mx-4.success-field
|
||||
label.form-label.m-0(for="postal_code")='Код подразделения'
|
||||
input.form-control.tg_input#postal_code
|
||||
small="(Пожалуйста, проверьте формат ввода)"
|
||||
.my-3.mx-4.success-field
|
||||
label.form-label.m-0(for="passport_issued_by")='Кем выдан паспорт'
|
||||
select.form-select.tg_input#passport_issued_by(style="")
|
||||
option(disabled, selected)="Кем выдан паспорт"
|
||||
small="(Пожалуйста, проверьте формат ввода)"
|
||||
.my-3.mx-4.success-field
|
||||
label.form-label.m-0(for="address")='Адрес регистрации в формате: РЕГИОН, НАСЕЛЕННЫЙ ПУНКТ, УЛИЦА, ДОМ, КВАРТИРА'
|
||||
input.form-control.tg_input#address
|
||||
small="(Пожалуйста, проверьте формат ввода)"
|
||||
.my-3.mx-4.success-field
|
||||
label.form-label.m-0(for="residential_address")='Адрес проживания в формате: РЕГИОН, НАСЕЛЕННЫЙ ПУНКТ, УЛИЦА, ДОМ, КВАРТИРА'
|
||||
input.form-control.tg_input#residential_address
|
||||
small="(Пожалуйста, проверьте формат ввода)"
|
||||
.my-3.mx-4.success-field
|
||||
label.form-label.m-0(for="snils")='СНИЛС'
|
||||
input.form-control.tg_input#snils
|
||||
small="(Пожалуйста, проверьте формат ввода)"
|
||||
.my-3.mx-4.success-field
|
||||
label.form-label.m-0(for="inn")='ИНН'
|
||||
input.form-control.tg_input#inn
|
||||
|
||||
//.my-3.mx-4.success-field#verification(style="display: none;")
|
||||
label.form-label.m-0(for="kod")='Код верификации'
|
||||
input.form-control#kod
|
||||
small="(Пожалуйста, проверьте формат ввода)"
|
||||
|
||||
.my-3.mx-4
|
||||
|
||||
@@ -22,24 +22,6 @@ function validate_length(val, dest_len){
|
||||
$(document).ready(function(){
|
||||
|
||||
|
||||
const validateEmail = (email) => {
|
||||
return email.match(
|
||||
/^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/
|
||||
);
|
||||
};
|
||||
|
||||
const validate = () => {
|
||||
const email = $('#email').val();
|
||||
if(validateEmail(email)){
|
||||
$('#email').parent().removeClass('errors-field').addClass('success-field');
|
||||
} else{
|
||||
$('#email').parent().removeClass('success-field').addClass('errors-field');
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
$('#email').on('input', validate);
|
||||
|
||||
|
||||
$('body').append('<div id="error_alert" class="alert alert-danger" role="alert" style="position: fixed; top: 50px; left: 10%; right: 10%; z-index: 9999; display: none;">Ошибка<br><small id="alert_error_text"></small></div>');
|
||||
$('body').append('<div id="success_alert" class="alert alert-success" role="alert" style="position: fixed; top: 50px; left: 10%; right: 10%; z-index: 9999; display: none;">Успех<br><small id="alert_success_text"></small></div>');
|
||||
@@ -71,13 +53,6 @@ $(document).ready(function(){
|
||||
});
|
||||
|
||||
|
||||
$('#email').on('input', function() {
|
||||
let input = $(this).val();
|
||||
// Разрешаем только буквы, цифры, точки, дефисы и подчеркивания
|
||||
input = input.replace(/[^a-zA-Z0-9._@-]/g, '');
|
||||
// Обновляем поле ввода
|
||||
$(this).val(input);
|
||||
});
|
||||
|
||||
$('#tel').on('change', function() {
|
||||
if($(this).val().length != 16){
|
||||
@@ -87,132 +62,18 @@ $(document).ready(function(){
|
||||
}
|
||||
});
|
||||
|
||||
// Проверка на дату рождения (не старше 80 лет)
|
||||
$('#dob').on('change', function() {
|
||||
const dob = new Date($(this).val());
|
||||
const currentDate = new Date();
|
||||
const age = currentDate.getFullYear() - dob.getFullYear();
|
||||
|
||||
// Проверка на возраст (не старше 80 лет)
|
||||
if (age > 80 || (age === 80 && (currentDate.getMonth() < dob.getMonth() || (currentDate.getMonth() === dob.getMonth() && currentDate.getDate() < dob.getDate())))) {
|
||||
// Если возраст больше 80 лет, подсвечиваем ячейку как ошибку
|
||||
$(this).parent().removeClass('success-field').addClass('errors-field');
|
||||
} else {
|
||||
// Если возраст нормален, подсвечиваем ячейку как успешную
|
||||
$(this).parent().removeClass('errors-field').addClass('success-field');
|
||||
}
|
||||
});
|
||||
|
||||
$('#address').on('input', function () {
|
||||
let input = $(this).val();
|
||||
|
||||
// Преобразуем все символы в верхний регистр
|
||||
input = input.toUpperCase();
|
||||
|
||||
// Обновляем поле ввода
|
||||
$(this).val(input);
|
||||
|
||||
// Проверяем формат: должно быть минимум 5 частей, разделённых запятыми
|
||||
let parts = input.split(',');
|
||||
if (parts.length < 4 || parts.some(part => part.trim().length === 0)) {
|
||||
$(this).parent().removeClass('success-field').addClass('errors-field');
|
||||
} else {
|
||||
$(this).parent().removeClass('errors-field').addClass('success-field');
|
||||
}
|
||||
});
|
||||
|
||||
$('#residential_address').on('input', function () {
|
||||
let input = $(this).val();
|
||||
|
||||
// Преобразуем все символы в верхний регистр
|
||||
input = input.toUpperCase();
|
||||
|
||||
// Обновляем поле ввода
|
||||
$(this).val(input);
|
||||
|
||||
// Проверяем формат: должно быть минимум 5 частей, разделённых запятыми
|
||||
let parts = input.split(',');
|
||||
if (parts.length < 4 || parts.some(part => part.trim().length === 0)) {
|
||||
$(this).parent().removeClass('success-field').addClass('errors-field');
|
||||
} else {
|
||||
$(this).parent().removeClass('errors-field').addClass('success-field');
|
||||
}
|
||||
});
|
||||
|
||||
// Проверка на дату выдачи паспорта (выдан после 14, 20 или 45 лет)
|
||||
$('#passport_date').on('change', function() {
|
||||
const passportDate = new Date($(this).val());
|
||||
const dob = new Date($('#dob').val());
|
||||
|
||||
// Проверка, что дата рождения введена и корректна
|
||||
if (!dob || isNaN(dob)) {
|
||||
// Если дата рождения не введена или неверна, показываем ошибку
|
||||
$(this).parent().removeClass('success-field').addClass('errors-field');
|
||||
return;
|
||||
}
|
||||
|
||||
const ageAtPassportIssue = passportDate.getFullYear() - dob.getFullYear();
|
||||
|
||||
// Проверка на возраст, в котором может быть выдан паспорт
|
||||
if (ageAtPassportIssue > 12) {
|
||||
// Если возраст при выдаче паспорта соответствует требованиям, подсвечиваем ячейку как успешную
|
||||
$(this).parent().removeClass('errors-field').addClass('success-field');
|
||||
} else {
|
||||
// Если возраст не соответствует, показываем ошибку
|
||||
$(this).parent().removeClass('success-field').addClass('errors-field');
|
||||
}
|
||||
});
|
||||
|
||||
$("#passport").attr('maxlength','12');
|
||||
|
||||
$('#passport').on('input', function() {
|
||||
let input = $(this).val();
|
||||
// Удаляем все символы, кроме цифр и пробелов
|
||||
input = input.replace(/\D/g, '');
|
||||
|
||||
// Форматируем ввод в "00 00 000000" с пробелами
|
||||
if (input.length > 2 && input.length <= 4) {
|
||||
input = input.replace(/(\d{2})(\d{0,2})/, '$1 $2');
|
||||
} else if (input.length > 4 && input.length <= 10) {
|
||||
input = input.replace(/(\d{2})(\d{2})(\d{0,6})/, '$1 $2 $3');
|
||||
}
|
||||
|
||||
// Ограничиваем длину до "00 00 000000"
|
||||
if (input.length > 12) {
|
||||
input = input.slice(0, 12);
|
||||
}
|
||||
|
||||
// Обновляем поле ввода
|
||||
$(this).val(input);
|
||||
|
||||
// Проверка на минимальную длину (не менее 11 символов)
|
||||
if (input.length < 12) {
|
||||
// Если введено меньше цифр, показываем ошибку
|
||||
$(this).parent().removeClass('success-field').addClass('errors-field');
|
||||
} else {
|
||||
// Если введено достаточно цифр, показываем успех
|
||||
$(this).parent().removeClass('errors-field').addClass('success-field');
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
$('#postal_code').on('input', function() {
|
||||
$("#dob").attr('maxlength','4');
|
||||
$('#dob').on('input', function() {
|
||||
let input = $(this).val();
|
||||
// Удаляем все символы, кроме цифр
|
||||
input = input.replace(/\D/g, '');
|
||||
// Форматируем ввод в "000-000" только при наличии 4 и более цифр
|
||||
if (input.length > 3) {
|
||||
input = input.replace(/(\d{3})(\d{0,3})/, '$1-$2');
|
||||
}
|
||||
// Ограничиваем длину до "000-000"
|
||||
if (input.length > 7) {
|
||||
input = input.slice(0, 7);
|
||||
}
|
||||
// Обновляем поле ввода
|
||||
$(this).val(input);
|
||||
|
||||
// Проверка на минимальную длину (не менее 11 символов)
|
||||
if (input.length < 7) {
|
||||
if (input.length < 4) {
|
||||
// Если введено меньше цифр, показываем ошибку
|
||||
$(this).parent().removeClass('success-field').addClass('errors-field');
|
||||
} else {
|
||||
@@ -221,64 +82,17 @@ $(document).ready(function(){
|
||||
}
|
||||
});
|
||||
|
||||
$('#passport_issued_by').select2({
|
||||
theme: 'bootstrap-5'
|
||||
});
|
||||
|
||||
$("#postal_code").change(function(){
|
||||
$('#passport_issued_by').empty();
|
||||
$('#passport_issued_by').append('<option disabled="" selected="">Кем выдан паспорт</option>')
|
||||
for(i in UFMS_list[$(this).val()])
|
||||
{
|
||||
item = UFMS_list[$(this).val()][i];
|
||||
$('#passport_issued_by').append('<option>'+item+'</option>');
|
||||
}
|
||||
// $('#passport_issued_by').select2("change");
|
||||
});
|
||||
|
||||
|
||||
$('#snils').on('input', function() {
|
||||
$("#kod").attr('maxlength','4');
|
||||
$('#kod').on('input', function() {
|
||||
let input = $(this).val();
|
||||
// Удаляем все символы, кроме цифр
|
||||
input = input.replace(/\D/g, '');
|
||||
|
||||
// Форматируем ввод в "000-000-000-00" только после 3, 6, 9 цифр
|
||||
if (input.length > 3 && input.length <= 6) {
|
||||
input = input.replace(/(\d{3})(\d{0,3})/, '$1-$2');
|
||||
} else if (input.length > 6 && input.length <= 9) {
|
||||
input = input.replace(/(\d{3})(\d{3})(\d{0,3})/, '$1-$2-$3');
|
||||
} else if (input.length > 9) {
|
||||
input = input.replace(/(\d{3})(\d{3})(\d{3})(\d{0,2})/, '$1-$2-$3-$4');
|
||||
}
|
||||
|
||||
// Ограничиваем длину до "000-000-000-00"
|
||||
if (input.length > 14) {
|
||||
input = input.slice(0, 14);
|
||||
}
|
||||
|
||||
// Обновляем поле ввода
|
||||
$(this).val(input);
|
||||
if (input.length < 14) {
|
||||
// Если введено меньше цифр, показываем ошибку
|
||||
$(this).parent().removeClass('success-field').addClass('errors-field');
|
||||
} else {
|
||||
// Если введено достаточно цифр, показываем успех
|
||||
$(this).parent().removeClass('errors-field').addClass('success-field');
|
||||
}
|
||||
});
|
||||
|
||||
$("#inn").attr('maxlength','12');
|
||||
$('#inn').on('input', function() {
|
||||
let input = $(this).val();
|
||||
// Убираем все символы, кроме цифр
|
||||
input = input.replace(/\D/g, '');
|
||||
// Ограничиваем длину до 12 символов
|
||||
if (input.length > 12) {
|
||||
input = input.slice(0, 12);
|
||||
}
|
||||
// Обновляем значение в поле ввода
|
||||
$(this).val(input);
|
||||
if (input.length < 12) {
|
||||
// Проверка на минимальную длину (не менее 11 символов)
|
||||
if (input.length < 4) {
|
||||
// Если введено меньше цифр, показываем ошибку
|
||||
$(this).parent().removeClass('success-field').addClass('errors-field');
|
||||
} else {
|
||||
@@ -288,6 +102,7 @@ $(document).ready(function(){
|
||||
});
|
||||
|
||||
$("#form_submit").click(function(){
|
||||
|
||||
$(this).children(".spinner-border").removeClass('d-none');
|
||||
$(this).attr("disabled", true);
|
||||
message = {}
|
||||
@@ -309,79 +124,13 @@ $(document).ready(function(){
|
||||
return;
|
||||
}
|
||||
|
||||
if ($('#dob').val().length !== 10 || new Date().getFullYear() - new Date($('#dob').val()).getFullYear() > 80) {
|
||||
if ($('#dob').val().length !== 4 || new Date().getFullYear() - new Date($('#dob').val()).getFullYear() > 80) {
|
||||
show_error('Дата рождения должна быть корректной и возраст не более 80 лет', false);
|
||||
$(this).children(".spinner-border").addClass('d-none');
|
||||
$(this).removeAttr("disabled");
|
||||
return;
|
||||
}
|
||||
|
||||
if(!(validateEmail($('#email').val()))){
|
||||
show_error('Введите корректный Email', false);
|
||||
$(this).children(".spinner-border").addClass('d-none');
|
||||
$(this).removeAttr("disabled");
|
||||
return;
|
||||
}
|
||||
|
||||
if(!(validate_length($('#passport').val(), 12)))
|
||||
{
|
||||
show_error('Введите серию и номер паспорта', false);
|
||||
$(this).children(".spinner-border").addClass('d-none');
|
||||
$(this).removeAttr("disabled");
|
||||
return;
|
||||
}
|
||||
|
||||
if ($('#passport_date').val().length !== 10 || (new Date($('#passport_date').val()).getFullYear() - new Date($('#dob').val()).getFullYear()) < 13) {
|
||||
show_error('Проверьте дату выдачи паспорта, паспорт РФ может быть выдан с 14 лет', false);
|
||||
$(this).children(".spinner-border").addClass('d-none');
|
||||
$(this).removeAttr("disabled");
|
||||
return;
|
||||
}
|
||||
|
||||
if(!(validate_length($('#postal_code').val(), 7)))
|
||||
{
|
||||
show_error('Введите код подразделения', false);
|
||||
$(this).children(".spinner-border").addClass('d-none');
|
||||
$(this).removeAttr("disabled");
|
||||
return;
|
||||
}
|
||||
|
||||
if($('#passport_issued_by').val() == null){
|
||||
show_error("Выберите кем выдан паспорт");
|
||||
$(this).children(".spinner-border").addClass('d-none');
|
||||
$(this).removeAttr("disabled");
|
||||
return;
|
||||
}
|
||||
|
||||
if ($('#address').val().split(',').length < 4 || $('#address').val().split(',').some(part => part.trim().length === 0)) {
|
||||
show_error('Пожалуйста, введите адрес регистрации в следующем формате, используя заглавные буквы и расставляя все запятые:\nРЕГИОН, НАСЕЛЕННЫЙ ПУНКТ, УЛИЦА, ДОМ, КВАРТИРА', false);
|
||||
$(this).children(".spinner-border").addClass('d-none');
|
||||
$(this).removeAttr("disabled");
|
||||
return;
|
||||
}
|
||||
|
||||
if ($('#residential_address').val().split(',').length < 4 || $('#residential_address').val().split(',').some(part => part.trim().length === 0)) {
|
||||
show_error('Пожалуйста, введите адрес проживания в следующем формате, используя заглавные буквы и расставляя все запятые:\nРЕГИОН, НАСЕЛЕННЫЙ ПУНКТ, УЛИЦА, ДОМ, КВАРТИРА', false);
|
||||
$(this).children(".spinner-border").addClass('d-none');
|
||||
$(this).removeAttr("disabled");
|
||||
return;
|
||||
}
|
||||
|
||||
if(!(validate_length($('#snils').val(), 14)))
|
||||
{
|
||||
show_error('Введите СНИЛС', false);
|
||||
$(this).children(".spinner-border").addClass('d-none');
|
||||
$(this).removeAttr("disabled");
|
||||
return;
|
||||
}
|
||||
|
||||
if(!(validate_length($('#inn').val(), 12)))
|
||||
{
|
||||
show_error('Введите ИНН', false);
|
||||
$(this).children(".spinner-border").addClass('d-none');
|
||||
$(this).removeAttr("disabled");
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user