Browse Source

first commit

master
Ilya_Chis 1 month ago
parent
commit
2ec8a806e6
  1. 4
      config.ini
  2. BIN
      webApp/interfaces/__pycache__/pagesController.cpython-38.pyc
  3. 27
      webApp/interfaces/pagesController.py
  4. 46
      webApp/templates/2.0/main_page.pug
  5. 269
      webApp/templates/static/js/2.0.dashboard.js

4
config.ini

@ -1,6 +1,6 @@
[WEB_APP]
PORT = 8084
template_folder = C:\Users\ilyac\PycharmProjects\tgFlaskForm\webApp\templates
PORT = 8083
template_folder = C:\Users\ilyac\PycharmProjects\tgFlaskFormPolimed\webApp\templates
environment = test
[GOOGLE]
type = service_account

BIN
webApp/interfaces/__pycache__/pagesController.cpython-38.pyc

Binary file not shown.

27
webApp/interfaces/pagesController.py

@ -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'] # Записываем время отправки данных

46
webApp/templates/2.0/main_page.pug

@ -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

269
webApp/templates/static/js/2.0.dashboard.js

@ -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;
}

Loading…
Cancel
Save