File size: 14,235 Bytes
87d1369
0dbef86
 
55ecd21
 
9859341
55ecd21
3d64aa1
 
 
 
 
 
 
55ecd21
3d64aa1
 
 
 
 
 
 
55ecd21
76163a7
3d64aa1
55ecd21
 
 
 
 
 
 
 
 
 
 
3d64aa1
 
 
 
 
55ecd21
3d64aa1
 
 
 
 
 
55ecd21
3d64aa1
 
 
55ecd21
3d64aa1
 
 
 
55ecd21
 
3d64aa1
55ecd21
3d64aa1
 
 
55ecd21
3d64aa1
 
 
 
 
 
 
55ecd21
3d64aa1
 
 
 
 
55ecd21
 
3d64aa1
 
 
 
55ecd21
3d64aa1
 
 
 
 
55ecd21
3d64aa1
 
 
 
 
 
55ecd21
3d64aa1
 
 
 
 
 
55ecd21
3d64aa1
 
 
 
 
55ecd21
3d64aa1
 
 
 
55ecd21
 
51edcac
 
 
 
 
 
 
 
 
 
 
55ecd21
51edcac
 
 
9859341
0dbef86
a9adc70
9b1491d
81c9369
55ecd21
9b1491d
9859341
 
1278675
 
 
55d96e7
cf609df
1278675
 
55d96e7
cf609df
1278675
 
55d96e7
cf609df
1278675
 
55d96e7
cf609df
1278675
 
55d96e7
227bb37
1278675
 
55d96e7
227bb37
1278675
 
 
 
 
9b1491d
55ecd21
1278675
 
 
55ecd21
 
1278675
e53811d
 
b333ce5
e53811d
9859341
87d1369
9859341
87d1369
9b1491d
943eb46
1651e07
 
 
 
 
 
 
 
 
 
bc8597f
1651e07
55ecd21
1651e07
 
 
5992b6f
1651e07
 
5992b6f
1651e07
 
8313773
1651e07
feda564
55ecd21
f6a91bc
 
4e56f05
 
5b2b2cc
55ecd21
 
0b6bc0c
fabae42
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
8436df1
1c19879
fabae42
 
 
 
 
 
 
 
8436df1
1c19879
fabae42
fbfba33
fabae42
 
 
 
 
8436df1
fabae42
 
e20f377
1c19879
 
 
 
 
 
 
 
fbfba33
 
 
 
 
 
1c19879
 
 
7416a7c
23fbc51
1bf0576
 
fabae42
 
 
 
 
 
 
fbfba33
fabae42
1c19879
 
fbfba33
e20f377
fbfba33
 
 
1c19879
a363dd9
bbe8126
 
 
 
db46642
e588661
bbe8126
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
a363dd9
073cced
4e56f05
38c91f0
4e56f05
9b1491d
87d1369
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
<!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;
}

h1 {
    background-color: #2e8b57;
    color: white;
    text-align: center;
    padding: 1em;
    border-radius: 10px;
    margin-bottom: 20px;
    width: 1000px;
    box-sizing: border-box;
}

/* Основные блоки */
fieldset, .calculation-box {
    border: 2px solid #2e8b57;
    background-color: #eaffea;
    padding: 1em;
    margin-bottom: 20px;
    border-radius: 8px;
    width: 1000px;
}

legend {
    font-weight: bold;
    color: #2e8b57;
    padding: 0 10px;
}

.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;
    gap: 5px; /* Добавлен отступ между меткой и полем ввода */
    margin-bottom: 10px; /* Добавлен вертикальный отступ между полями */
}

.profile-label {
    font-weight: bold;
}

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

/* Кнопка */
#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;
    margin-bottom: 5px;
}

#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>
</fieldset>





<script>
let call_data;
  
document.getElementById('calculate-btn').addEventListener('click', function() {
    console.log("=== НАЧАЛО ОБРАБОТКИ ===");
    
    // 1. Получаем значение точности округления с подробным логированием
    const roundingInput = document.getElementById('rounding-precision');
    console.log("Значение поля rounding-precision (raw):", roundingInput.value);
    
    const initialRounding = parseInt(roundingInput.value);
    console.log("Парсинг значения rounding (после parseInt):", initialRounding);
    
    const roundingPrecision = Math.min(Math.max(initialRounding || 3, 0), 6);
    console.log("Финальное значение точности (0-6):", roundingPrecision);
    
    // 2. Улучшенная функция для безопасного получения числового значения с логированием
    const getValue = (id) => {
        const element = document.getElementById(id);
        if (!element) {
            console.error(`Элемент с ID ${id} не найден!`);
            return 0;
        }
        console.log(`Значение поля ${id}:`, element.value);
        
        const value = parseFloat(element.value);
        const result = isNaN(value) ? 0 : value;
        
        console.log(`Парсинг значения ${id}:`, result);
        return result;
    };
    // 3. Формируем данные для сервера с пошаговым логированием
    console.log("=== ФОРМИРОВАНИЕ ДАННЫХ ДЛЯ СЕРВЕРА ===");
    
    const fertilizerConstants = {
        "Кальциевая селитра": {
            "N (NO3-)": getValue('fert_ca_no3') / 100,
            "Ca": getValue('fert_ca_ca') / 100
        },
        "Калий азотнокислый": {
            "N (NO3-)": getValue('fert_kno3_no3') / 100,
            "K": getValue('fert_kno3_k') / 100
        },
        "Аммоний азотнокислый": {
            "N (NO3-)": getValue('fert_nh4no3_no3') / 100,
            "N (NH4+)": getValue('fert_nh4no3_nh4') / 100
        },
        "Сульфат магния": {
            "Mg": getValue('fert_mgso4_mg') / 100,
            "S": getValue('fert_mgso4_s') / 100
        },
        "Монофосфат калия": {
            "P": getValue('fert_kh2po4_p') / 100,
            "K": getValue('fert_kh2po4_k') / 100
        },
        "Калий сернокислый": {
            "K": getValue('fert_k2so4_k') / 100,
            "S": getValue('fert_k2so4_s') / 100
        }
    };
    
    const profileSettings = {
        'P': getValue('profile_p'),
        'K': getValue('profile_k'),
        'Mg': getValue('profile_mg'),
        'Ca': getValue('profile_ca'),
        'S': getValue('profile_s'),
        'NO3_RAT': getValue('profile_no3'),
        'TOTAL_NITROG': getValue('profile_n'),
        'liters': parseInt(document.getElementById('liters-input').value) || 1,
        'rounding_precision': roundingPrecision
    };
    
    const requestData = {
        fertilizerConstants: fertilizerConstants,
        profileSettings: profileSettings
    };
    
    console.log("=== ПОЛНЫЙ ОБЪЕКТ ДЛЯ ОТПРАВКИ ===", JSON.stringify(requestData, null, 2));
    
    // 4. Проверка данных с подробным выводом
    console.log("=== ПРОВЕРКА ДАННЫХ ===");
    
    const requiredFertilizers = ["Кальциевая селитра", "Калий азотнокислый", "Аммоний азотнокислый", 
                               "Сульфат магния", "Монофосфат калия", "Калий сернокислый"];
    
    let hasErrors = false;
    for (const fert of requiredFertilizers) {
        if (!requestData.fertilizerConstants[fert]) {
            console.error(`ОШИБКА: Отсутствует удобрение: ${fert}`);
            hasErrors = true;
        } else {
            console.log(`Удобрение ${fert} присутствует`);
        }
    }
    
    const requiredProfileFields = ['P', 'K', 'Mg', 'Ca', 'S', 'NO3_RAT', 'TOTAL_NITROG'];
    for (const field of requiredProfileFields) {
        if (isNaN(requestData.profileSettings[field])) {
            console.error(`ОШИБКА: Некорректное значение для параметра ${field}`);
            hasErrors = true;
        } else {
            console.log(`Параметр ${field} в порядке:`, requestData.profileSettings[field]);
        }
    }
    
    console.log("Параметр rounding_precision:", requestData.profileSettings.rounding_precision);
    
    if (hasErrors) {
        const errorMsg = "Пожалуйста, проверьте введенные данные. Обнаружены ошибки в форме. Смотрите консоль для деталей.";
        console.error(errorMsg);
        alert(errorMsg);
        return;
    }
    // 5. Отправка данных на сервер с полным логированием
    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;
        console.log("=== УСПЕШНЫЙ ОТВЕТ ОТ СЕРВЕРА ===", call_data);
            // Выводим данные в форму
             data_out(call_data);
        // Проверяем, применилась ли точность округления
        console.log("Проверка округления в ответе:");
        if (data.fertilizers) {
            Object.entries(data.fertilizers).forEach(([name, values]) => {
                console.log(`Удобрение ${name}:`, values);
            });
        }
        
        // Здесь можно добавить обработку ответа
    })
    .catch(error => {
        console.error("=== ОШИБКА ПРИ ОБРАБОТКЕ ===", error);
        alert("Ошибка при расчете: " + error.message);
    })
    .finally(() => {
        console.log("=== ЗАВЕРШЕНИЕ ОБРАБОТКИ ===");
    });
});




function data_out(response) {
 

    // Заполняем граммы для каждого удобрения
    const fertilizerGrams = {
        "Кальциевая селитра": "calcium_nitrate",
        "Калий азотнокислый": "potassium_nitrate",
        "Аммоний азотнокислый": "ammonium_nitrate",
        "Сульфат магния": "magnesium_sulfate",
        "Монофосфат калия": "monopotassium_phosphate",
        "Калий сернокислый": "potassium_sulfate"
    };

    for (const [fertName, gramsFieldId] of Object.entries(fertilizerGrams)) {
        const fertData = response.fertilizers[fertName];
        if (fertData) {
            const gramsInput = document.getElementById(gramsFieldId);
            if (gramsInput) {
                gramsInput.value = fertData.граммы.toFixed(3);
            } else {
                console.error(`Не найден элемент для ввода граммов: ${gramsFieldId}`);
            }
        }
    }

    // Выводим общую EC
    const ecInput = document.getElementById('profile_ec');
    if (ecInput && response.total_ec) {
        ecInput.value = response.total_ec.toFixed(2);
    }

    console.log("Данные успешно выведены в форму");
}


  
</script>



  
</body>
</html>