Исправлено сравнение значений для выпадающих списков и форматирование чисел
- Унифицировано сравнение через normalizeValue() для всех типов ячеек - Intl.NumberFormat с сохранением исходного количества знаков после запятой Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -509,7 +509,12 @@ async function selectTable(schema, tableName) {
|
|||||||
if (value === null || value === undefined || value === '') return '';
|
if (value === null || value === undefined || value === '') return '';
|
||||||
const num = parseFloat(value);
|
const num = parseFloat(value);
|
||||||
if (isNaN(num)) return value;
|
if (isNaN(num)) return value;
|
||||||
return num.toLocaleString('ru-RU');
|
// Определяем количество знаков после запятой из исходного значения
|
||||||
|
const decimalPlaces = (String(value).split('.')[1] || '').length;
|
||||||
|
return new Intl.NumberFormat('ru-RU', {
|
||||||
|
minimumFractionDigits: 0,
|
||||||
|
maximumFractionDigits: Math.min(decimalPlaces, 6)
|
||||||
|
}).format(num);
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
// ✅ Добавляем тултип для заголовка
|
// ✅ Добавляем тултип для заголовка
|
||||||
@@ -915,12 +920,12 @@ async function selectTable(schema, tableName) {
|
|||||||
const newValue = cell.getValue();
|
const newValue = cell.getValue();
|
||||||
|
|
||||||
// Проверяем, действительно ли значение изменилось
|
// Проверяем, действительно ли значение изменилось
|
||||||
// Учитываем преобразование типов (число vs строка)
|
// Учитываем преобразование типов и пустые значения
|
||||||
const valuesEqual = oldValue === newValue ||
|
const normalizeValue = (v) => {
|
||||||
(oldValue == null && newValue === '') ||
|
if (v === null || v === undefined || v === '') return null;
|
||||||
(oldValue === '' && newValue == null) ||
|
return String(v);
|
||||||
(typeof oldValue === 'number' && String(oldValue) === newValue) ||
|
};
|
||||||
(typeof newValue === 'number' && String(newValue) === oldValue);
|
const valuesEqual = normalizeValue(oldValue) === normalizeValue(newValue);
|
||||||
|
|
||||||
if (valuesEqual) {
|
if (valuesEqual) {
|
||||||
console.log('⏭️ Значение не изменилось:', cell.getField(), oldValue, '→', newValue);
|
console.log('⏭️ Значение не изменилось:', cell.getField(), oldValue, '→', newValue);
|
||||||
|
|||||||
Reference in New Issue
Block a user