Каждый раз когда я помогаю кому-то с электрикой, происходит одно и то же. Человек спрашивает «какой кабель на розетки?». Я говорю «2.5 мм²». Он спрашивает «а автомат?». Я говорю «C16». Потом: «а сколько метров нужно?», «а УЗО куда?», «а сколько это будет стоить?». И вот уже час объяснений, Excel непонятного происхождения и ощущение что что-то всё равно забыли.
Я решил сделать инструмент который отвечает на всё сразу. Добавил комнаты, указал приборы и расстояние до щитка — нажал кнопку — получил группы, кабели, автоматы, схему щитка и смету. Без регистрации, без интернета, без установки.
Получился один HTML-файл на ~1400 строк ванильного JS.
https://darkenamber.github.io/electrokit/

Флоу работы
Четыре шага:
-
Добавить комнаты и приборы
-
Указать расстояние от каждой комнаты до щитка
-
Нажать «Рассчитать»
-
Получить таблицу групп, схему щитка, полную смету и список ошибок если они есть
Расстояние до щитка — почему на уровне комнаты
Длина линии нужна для двух вещей: стоимость кабеля в смете и проверка ΔU%. Если вводить длину отдельно для каждой из 12 групп после расчёта — неудобно. Если одно число на весь объект — неточно, потому что кабели разного сечения имеют разную цену за метр.
Решение: одно поле «до щитка, м» на уровне комнаты. Электрик знает примерно сколько метров от гостиной до щитка. Это число подставляется во все группы комнаты автоматически. Если нужна точность по конкретной группе — корректируешь в таблице результатов.

Подбор кабеля — где легко ошибиться
Наивная реализация:
function cableForLoad(watts) { const a = watts / 220; if (a <= 16) return { section: '1.5', breaker: 16 }; if (a <= 25) return { section: '2.5', breaker: 25 }; if (a <= 32) return { section: '4.0', breaker: 32 }; // ...}
Проблема: духовка 2500 Вт даёт ток 11.4 А и получает 1.5 мм². Формально верно. Практически — нет. Для выделенных линий минимум 2.5 мм².
Вторая проблема: для мощных нагрузок нужен коэффициент запаса, иначе кабель работает на пределе.
Итоговая реализация:
// lineType: 'lighting' | 'socket' | 'dedicated' | 'ac' | 'custom'function cableForLoad(watts, lineType) { // Коэффициент 1.25 для выделенных линий и кондиционеров const margin = (lineType === 'dedicated' || lineType === 'ac') ? 1.25 : 1.0; const a = (watts * margin) / 220; // Минимальное сечение по типу линии - ключевой момент const minSec = (lineType === 'socket' || lineType === 'dedicated' || lineType === 'ac') ? 2.5 : 1.5; let section, breaker; if (a <= 16) { section = 1.5; breaker = 16; } else if (a <= 25) { section = 2.5; breaker = 25; } else if (a <= 32) { section = 4.0; breaker = 32; } else if (a <= 40) { section = 6.0; breaker = 40; } else { section = 10; breaker = 63; } // Применить минимум независимо от расчёта if (section < minSec) section = minSec; return { section: String(section), breaker };}
Теперь духовка 2500 Вт: ток с коэффициентом 14.2 А, расчётное сечение 1.5 мм², но минимум для выделенной линии 2.5 мм². Результат: 2.5 мм² + C16. Именно так и принято на практике.
Мокрые зоны — без ручных флагов
Инструмент сам определяет мокрые зоны по названию комнаты:
const WET_KW = ['ван', 'санузел', 'туалет', 'кухн', 'баня', 'душ', 'bathroom', 'kitchen', 'toilet', 'wc'];function isWetRoom(name) { return WET_KW.some(k => name.toLowerCase().includes(k));}
Пользователь называет комнату «Ванная» — инструмент автоматически ставит дифавтомат для всех групп этой комнаты и добавляет УЗО 25А/30мА в схему щитка. Кондиционеры — исключение, они всегда на сухих линиях даже в ванной.
function voltDrop(watts, lengthM, sectionStr) { // ΔU% = (2 × L × I × ρ) / (S × U) × 100 // ρ = 0.0175 Ω·мм²/м для меди const I = watts / 220; return (2 * lengthM * I * 0.0175) / (parseFloat(sectionStr) * 220) * 100;}
Считается сразу после нажатия «Рассчитать» по введённым расстояниям. Показывается в таблице рядом с длиной линии:
-
Зелёный — ΔU < 4%
-
Жёлтый — ΔU 4-5%
-
Красный — ΔU > 5% с подсказкой «→ 4.0 мм²»
По ПУЭ норма не более 5% для жилых помещений. Рекомендуется держать до 4%.
Проверки — то чего обычно нет в калькуляторах
Перегрузка вводного автомата
javascript
const totalA = totalKd / 220;if (totalA > mainBreaker) { // красная ошибка: расчётный ток X А превышает вводной Y А}
Нарушение селективности
Это самая важная проверка. Если групповой автомат >= вводному — при КЗ сработают оба одновременно. Обесточится весь щит, а не только одна линия.
javascript
const badGroups = groups.filter(g => !g.wet && g.breaker >= mainBreaker);if (badGroups.length) { // показать список виновных групп с номиналами // и объяснение что именно происходит при КЗ}

Рекомендации
Отдельный синий блок — не ошибки, просто советы:
javascript
// Вводной загружен больше 80%const loadPct = (totalA / mainBreaker) * 100;if (loadPct > 80 && totalA <= mainBreaker) { tips.push(`Вводной загружен на ${Math.round(loadPct)}%. Запас менее 20%...`);}// Слишком много на одной розеточной группеconst heavySockets = groups.filter(g => g.lineType === 'socket' && g.watts > 3500);// Много розеток на одной линииconst crowded = groups.filter(g => g.lineType === 'socket' && g.socketCount > 6);// Размер щиткаconst totalModules = 2 + wetRooms.size + groups.length;if (totalModules > 16) tips.push(`Щиток потребует ~${totalModules} модулей. Возьмите на 24 места.`);
Схема щитка
Порядок модулей фиксированный:
-
Вводной автомат — оранжевый
-
УЗО вводное — следующий стандартный номинал >= вводного — голубой
-
УЗО для каждой мокрой зоны 25А/30мА — синий
-
Групповые автоматы: зелёный <= 16А, жёлтый <= 32А, красный > 32А
-
Дифавтоматы мокрых групп — синий
const UZO_STD = [16, 25, 40, 63, 80, 100];function uzoRating(mainA) { return UZO_STD.find(r => r >= mainA) || 100;}

Смета
Считается автоматически из результатов расчёта. Два столбца:
Материалы:
-
Кабель — метраж по каждому сечению × своя цена/м
-
Автоматы по номиналам — из всех групп + вводной
-
Дифавтоматы — количество мокрых групп
-
УЗО — 1 вводное + по одному на мокрую зону
-
Щиток, розетки, выключатели, подрозетники
Работы:
-
Прокладка и штробление — по суммарному метражу
-
Установка розеток и выключателей
-
Сборка щитка — фиксированная ставка
-
Подключение групп
Все цены настраиваются в панели настроек. Валюта — любая, пишешь свою.

Хранение данных
localStorage.setItem('ek_proj', JSON.stringify({ name, type, breaker, note, rooms, _saved: new Date().toISOString()}));localStorage.setItem('ek_cfg', JSON.stringify(settings));
Сохраняется автоматически при каждом изменении. В настройках показывается сколько занято в КБ, когда последнее сохранение и три кнопки: очистить проект, сбросить цены, удалить всё.
Плюс экспорт/импорт в JSON — передать проект коллеге или хранить несколько объектов как файлы.
Почему один файл
Сознательная позиция, не лень разбивать на модули.
Один файл — это скинуть коллеге в Telegram одним сообщением, открыть на объекте без интернета, никаких проблем с CDN и обновлениями. Единственная внешняя зависимость — Google Fonts. При отсутствии интернета браузер использует системный шрифт, всё работает.
Что не считает
Честно о границах:
-
Трёхфазная сеть (в планах)
-
Реактивная мощность и cos φ
-
Токи короткого замыкания
-
Термическая стойкость кабеля при КЗ
ElectroKit — инструмент для предварительной оценки. Не замена проектной документации.
Стек
|
Что |
Чем |
|---|---|
|
Логика расчётов |
Vanilla JS |
|
UI |
HTML + CSS переменные |
|
Хранение |
localStorage |
|
|
window.print() + print CSS |
|
Импорт/экспорт |
JSON + Blob API |
|
Зависимости |
0 |
Что дальше
Инструмент сырой — это MVP, не финальный продукт. Использовать можно, но с пониманием ограничений описанных выше.
В планах:
PWA — манифест + service worker, иконка на главном экране. Технически это час работы поверх текущего HTML. Тогда не нужно хранить файл на телефоне и каждый раз искать его — просто иконка как у обычного приложения.
Android APK — нативное приложение под брендом DarkenAmber. Удобный ввод на телефоне одной рукой, работа на объекте без браузера, нормальный экспорт PDF через системный диалог. Когда именно — зависит от того насколько инструмент окажется востребованным в текущем виде.
SVG однолинейная схема — настоящая однолинейка прямо в браузере, не просто визуализация DIN-рейки.
XLSX экспорт сметы — для тех кто привык работать с Excel.
Трёхфазный режим — для частных домов и небольших коммерческих объектов.
Если пользуетесь и чего-то не хватает — пишите в Issues, это реально влияет на приоритеты.
ссылка на оригинал статьи https://habr.com/ru/articles/1051896/