api_g / nutri_call.html
DmitrMakeev's picture
Update nutri_call.html
f230e6a verified
raw
history blame
14.2 kB
<!DOCTYPE html>
<html lang="ru">
<head>
<meta charset="UTF-8">
<title>Калькулятор удобрений</title>
<style>
body {
margin: 0 auto;
width: 1000px;
padding: 1em;
background-color: #f0f0f0;
font-family: Arial, sans-serif;
}
fieldset {
border: 2px solid #2e8b57;
background-color: #eaffea;
padding: 1em;
margin-bottom: 20px;
border-radius: 8px;
}
h1 {
background-color: #2e8b57;
color: white;
text-align: center;
padding: 1em;
border-radius: 10px;
margin-bottom: 20px;
}
legend {
font-weight: bold;
color: #2e8b57;
padding: 0 10px;
}
input[type=number] {
width: 80px;
padding: 3px;
border: 1px solid #ccc;
border-radius: 4px;
}
/* Общие стили для обоих блоков */
.main-container {
display: grid;
grid-template-columns: 120px repeat(8, 90px);
gap: 10px;
padding: 10px;
}
/* Верхний блок - макропрофиль */
.profile-container {
display: contents;
}
.profile-element {
display: flex;
flex-direction: column;
align-items: center;
}
.profile-label {
font-weight: bold;
margin-bottom: 5px;
}
/* Азотные элементы */
.nitrogen-container {
grid-column: 1 / -1;
display: flex;
gap: 20px;
padding-left: 120px;
margin-top: 10px;
}
.nitrogen-group {
display: flex;
align-items: center;
gap: 5px;
}
/* Нижний блок - составы солей (переделан в горизонтальный) */
.fertilisers-container {
display: flex;
flex-direction: column;
}
.fert-row {
display: flex;
align-items: center;
margin-bottom: 10px;
}
.fert-header {
font-weight: bold;
text-align: center;
min-width: 90px;
padding: 5px;
}
.fert-name {
font-weight: bold;
min-width: 120px;
text-align: left;
padding-right: 10px;
}
.fert-cell {
text-align: center;
min-width: 90px;
padding: 5px;
}
.fert-input {
width: 80px;
margin: 0 5px;
}
/* Стиль для новой рамки с кнопкой */
/* Стиль для блока расчёта */
.calculation-box {
border: 2px solid #2e8b57;
background-color: #eaffea;
padding: 1em;
margin-bottom: 20px;
border-radius: 8px;
}
.calculation-box legend {
font-weight: bold;
color: #2e8b57;
padding: 0 10px;
}
.calculation-container {
display: flex;
align-items: center;
gap: 10px;
}
.calculation-label {
font-weight: bold;
margin-right: 5px;
}
#liters-input {
width: 80px;
padding: 3px;
border: 1px solid #ccc;
border-radius: 4px;
}
#calculate-btn {
background-color: #2e8b57;
color: white;
border: none;
padding: 8px 16px;
font-size: 16px;
border-radius: 5px;
cursor: pointer;
transition: background-color 0.3s;
}
#calculate-btn:hover {
background-color: #3cb371;
}
</style>
</head>
<body>
<h1>Калькулятор удобрений</h1>
<fieldset>
<legend>Макропрофиль в мг/л (ppm)</legend>
<div class="main-container">
<!-- Основные элементы -->
<div class="profile-container">
<div class="profile-element" style="grid-column: 2">
<span class="profile-label">N</span>
<input id="profile_n" type="number" value="125.000" step="0.001"/>
</div>
<div class="profile-element" style="grid-column: 3">
<span class="profile-label">P</span>
<input id="profile_p" type="number" value="31.000" step="0.001"/>
</div>
<div class="profile-element" style="grid-column: 4">
<span class="profile-label">K</span>
<input id="profile_k" type="number" value="210.000" step="0.001"/>
</div>
<div class="profile-element" style="grid-column: 5">
<span class="profile-label">Ca</span>
<input id="profile_ca" type="number" value="84.000" step="0.001"/>
</div>
<div class="profile-element" style="grid-column: 6">
<span class="profile-label">Mg</span>
<input id="profile_mg" type="number" value="24.000" step="0.001"/>
</div>
<div class="profile-element" style="grid-column: 7">
<span class="profile-label">S</span>
<input id="profile_s" type="number" value="56.439" step="0.001"/>
</div>
<div class="profile-element" style="grid-column: 8">
<span class="profile-label">EC</span>
<input id="profile_ec" type="number" value="0.0" step="0.001"/>
</div>
</div>
<!-- Азотные элементы -->
<div class="nitrogen-container">
<div class="nitrogen-group">
<label for="profile_nh4">NH4:</label>
<input id="profile_nh4" type="number" value="1.0" step="1.0" readonly style="background-color: #f0f0f0; border: 1px solid #ccc; color: #666;">
</div>
<div class="nitrogen-group">
<label for="profile_no3">NO3:</label>
<input id="profile_no3" type="number" value="10.0" step="0.01" min="5" max="10.001"/>
</div>
</div>
</div>
</fieldset>
<fieldset>
<legend>Составы солей</legend>
<div class="fertilisers-container">
<!-- Заголовки -->
<div class="fert-row">
<span class="fert-name">Удобрение</span>
<span class="fert-header">NH4</span>
<span class="fert-header">NO3</span>
<span class="fert-header">P</span>
<span class="fert-header">K</span>
<span class="fert-header">Ca</span>
<span class="fert-header">Mg</span>
<span class="fert-header">S</span>
<span class="fert-header">Грамм</span>
</div>
<!-- Строки с удобрениями -->
<div class="fert-row">
<span class="fert-name">CaN2O6</span>
<span class="fert-cell">-</span>
<input class="fert-input" type="number" value="11.863" step="0.001" id="fert_ca_no3"/>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<input class="fert-input" type="number" value="16.972" step="0.001" id="fert_ca_ca"/>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<input class="fert-input" type="number" step="0.001" id="calcium_nitrate"/>
</div>
<div class="fert-row">
<span class="fert-name">KNO3</span>
<span class="fert-cell">-</span>
<input class="fert-input" type="number" value="13.854" step="0.001" id="fert_kno3_no3"/>
<span class="fert-cell">-</span>
<input class="fert-input" type="number" value="36.672" step="0.001" id="fert_kno3_k"/>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<input class="fert-input" type="number" step="0.001" id="potassium_nitrate"/>
</div>
<div class="fert-row">
<span class="fert-name">NH4NO3</span>
<input class="fert-input" type="number" value="17.499" step="0.001" id="fert_nh4no3_nh4"/>
<input class="fert-input" type="number" value="17.499" step="0.001" id="fert_nh4no3_no3"/>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<input class="fert-input" type="number" step="0.001" id="ammonium_nitrate"/>
</div>
<div class="fert-row">
<span class="fert-name">MgSO4</span>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<input class="fert-input" type="number" value="10.22" step="0.001" id="fert_mgso4_mg"/>
<input class="fert-input" type="number" value="13.483" step="0.001" id="fert_mgso4_s"/>
<input class="fert-input" type="number" step="0.001" id="magnesium_sulfate"/>
</div>
<div class="fert-row">
<span class="fert-name">KH2PO4</span>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<input class="fert-input" type="number" value="22.761" step="0.001" id="fert_kh2po4_p"/>
<input class="fert-input" type="number" value="28.731" step="0.001" id="fert_kh2po4_k"/>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<input class="fert-input" type="number" step="0.001" id="monopotassium_phosphate"/>
</div>
<div class="fert-row">
<span class="fert-name">K2SO4</span>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<input class="fert-input" type="number" value="44.874" step="0.001" id="fert_k2so4_k"/>
<span class="fert-cell">-</span>
<span class="fert-cell">-</span>
<input class="fert-input" type="number" value="18.401" step="0.001" id="fert_k2so4_s"/>
<input class="fert-input" type="number" step="0.001" id="potassium_sulfate"/>
</div>
</div>
</fieldset>
<fieldset class="calculation-box">
<legend>Расчёт удобрений</legend>
<div class="calculation-container">
<div class="calculation-label">Литры:</div>
<input type="number" id="liters-input" value="100" min="1" step="1">
<div class="calculation-label">Точность:</div>
<input type="number" id="rounding-precision" value="3" min="0" max="6" step="1">
<button id="calculate-btn">Рассчитать</button>
</div>
</fieldset>
<script>
// Глобальная переменная для хранения данных
let call_data = null;
// Функция для обработки данных (пример)
function processFertilizersData() {
if (!call_data || !call_data.fertilizers) {
console.error("Нет данных для обработки");
return;
}
console.log("Обработка данных удобрений:");
Object.entries(call_data.fertilizers).forEach(([name, values]) => {
console.log(`Обработка ${name}:`, values);
// Ваша логика обработки здесь
});
}
// Вторая функция для работы с данными (пример)
function displayResults() {
if (!call_data) {
console.error("Нет данных для отображения");
return;
}
console.log("Отображение результатов:");
console.log("Общий EC:", call_data.total_ec);
console.log("Общий PPM:", call_data.total_ppm);
if (call_data.actual_profile) {
console.log("Профиль питательных веществ:", call_data.actual_profile);
}
}
document.getElementById('calculate-btn').addEventListener('click', function() {
console.log("=== НАЧАЛО ОБРАБОТКИ ===");
// [Ваш существующий код получения и подготовки данных...]
fetch('/calculation', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify(requestData)
})
.then(response => {
console.log("Получен ответ от сервера. Статус:", response.status);
if (!response.ok) {
console.error("ОШИБКА СЕРВЕРА. Полный ответ:", response);
throw new Error(`HTTP error! status: ${response.status}`);
}
return response.json();
})
.then(data => {
// Сохраняем данные в глобальную переменную
call_data = data; // Исправлено: было call_data = data:
console.log("=== УСПЕШНЫЙ ОТВЕТ ОТ СЕРВЕРА ===", call_data);
// Вызываем функции обработки данных
processFertilizersData();
displayResults();
// Здесь можно добавить дополнительную обработку ответа
})
.catch(error => {
console.error("=== ОШИБКА ПРИ ОБРАБОТКЕ ===", error);
alert("Ошибка при расчете: " + error.message);
})
.finally(() => {
console.log("=== ЗАВЕРШЕНИЕ ОБРАБОТКИ ===");
});
});
// Пример использования данных в других частях приложения
document.getElementById('some-other-button').addEventListener('click', function() {
if (call_data) {
console.log("Использование сохраненных данных:", call_data);
// Дополнительная обработка данных
} else {
console.log("Данные еще не загружены");
}
});
</script>
</body>
</html>