<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Устройства</title>
    <link rel="stylesheet" href="../styles/main.css" />
</head>
<body>

    <header>
        <h1>Аргус</h1>
        <h2><span>/</span> Название организации</h2>
    </header>

    <section class="account-info">
      <div id="account-main">
          <img id="person" src="../img/person.svg">
          <span>Тестовое Имя</span>
          <img id="down" src="../img/down.svg">
          <img id="up" src="../img/up.svg">
      </div>
      <a href="/login"><div id="account-additional" class="additional">Выйти</div></a>
  </section>

    


    <section class="navigation">
        <a href="/">
            <div><img src="../img/chart.svg">Главная</div>
        </a>
        <a href="/devices">
            <div class="selected"><img src="../img/cloud.svg">Устройства</div>
        </a>
        <a href="/reports">
            <div><img src="../img/bubble.svg">Отчёты</div>
        </a>
        <a href="/live">
            <div><img src="../img/waves.svg">Трансляция</div>
        </a>
        <a href="/videos">
            <div><img src="../img/play.svg">Записи</div>
        </a>
        <a class="settings" href="/">
            <div><img src="../img/gear.svg">Настройки</div>
        </a>
    </section>

    <section class="main">
      {{#if ifDBError}}
      <section class="dberror">
        <div class="erorr-container">
          <img src="../img/warning.svg"> <br>
          <h1>Ошибка </h1> <br>
          <span>Не удалось получить данные из БД</span>
          <button type="button" onclick="location.reload();">Повторить попытку</button>
        </div>
      </section>
      {{/if}}
        <div class="name">
            <span>Устройства</span>
        </div>
        <nav>
            <a class="selected" href="/devices">Список устройств</a>
            <!-- <a href="/devices/drivers">Водители</a> -->
            <!-- <a href="/devices/newdevice">Добавить устройство</a> -->
            <!-- <a href="/devices/newdriver">Добавить водителя</a> -->

            <a class="update" href="/devices/update">Обновление ПО</a>
        </nav>
        <section class="bg">
            <section class="content">

                <section class="for-table">

                    <section class="organisation">
                        <h1>Организация</h1>

                        <ul class="area">
                            <li class="area-name"><img src="../img/ul.svg"><input type="checkbox" id="name-1" class="checkbox-input" hidden checked><label for="name-1" class="checkbox-label">Группа 1</label>
                              <ul class="area-devices" id="devices-1">
                                <li class="device"><img><input type="checkbox" id="1-device-1" class="checkbox-input device-filter" value="1-device-1" hidden checked><label for="1-device-1" class="checkbox-label"><div class="checkmark"></div>Автобусы</label></li>
                                <!-- <li class="device"><img><input type="checkbox" id="1-device-2" class="checkbox-input device-filter" value="1-device-2" hidden checked><label for="1-device-2" class="checkbox-label"><div class="checkmark"></div>Маршрутки</label></li> -->
                              </ul>
                            </li>
                            <!-- <li class="area-name"><img src="../img/ul.svg"><input type="checkbox" id="name-2" class="checkbox-input" hidden checked><label for="name-2" class="checkbox-label">Группа 2</label>
                              <ul class="area-devices" id="devices-2">
                                <li class="device"><img><input type="checkbox" id="2-device-1" class="checkbox-input device-filter" value="2-device-1" hidden checked><label for="2-device-1" class="checkbox-label"><div class="checkmark"></div>Трамваи</label></li>
                                <li class="device"><img><input type="checkbox" id="2-device-2" class="checkbox-input device-filter" value="2-device-2" hidden checked><label for="2-device-2" class="checkbox-label"><div class="checkmark"></div>Электробусы</label></li>
                                <li class="device"><img><input type="checkbox" id="2-device-3" class="checkbox-input device-filter" value="2-device-3" hidden checked><label for="2-device-3" class="checkbox-label"><div class="checkmark"></div>Троллейбусы</label></li>
                                <li class="device"><img><input type="checkbox" id="2-device-4" class="checkbox-input device-filter" value="2-device-4" hidden checked><label for="2-device-4" class="checkbox-label"><div class="checkmark"></div>Старые ТС</label></li>
                              </ul>
                            </li>
                            <li class="area-name"><img src="../img/ul.svg"><input type="checkbox" id="name-3" class="checkbox-input" hidden checked><label for="name-3" class="checkbox-label">Другое</label>
                              <ul class="area-devices" id="devices-3">
                                <li class="device"><img><input type="checkbox" id="3-device-1" class="checkbox-input device-filter" value="3-device-1" hidden checked><label for="3-device-1" class="checkbox-label"><div class="checkmark"></div>Маршрутки</label></li>
                              </ul>
                            </li> -->
                          </ul>
                          
                    </section>

                

                    <section id="table-area" class="table">
                        <h1>Список устройств</h1>
                        <input id="table-search" class="search" type="text" placeholder="Поиск">

                          
                          <table id="deviceTable">
                            <thead>
                              <tr>
                                <th><input id="device-all" type="checkbox"><label for="device-all"><div class="checkmark"></div></label></th>
                                <th>Группа</th>
                                <th>Номерной знак</th>
                                <th>Серийный номер</th>
                                <th>Статус</th>
                                <th>Номер SIM-карты</th>
                                <th>IP-адрес</th>
                                <th>Порт</th>
                                <th><button id="delete-device-all" value="delete-device-all" class="trash"></button></th>
                              </tr>
                            </thead>
                            <tbody>
                              <!-- Сюда будут добавляться строки таблицы -->
                            </tbody>
                          </table>
                          
                          
                          
                          
                    </section>

                    <div id="count">
                        <!-- Сюда добавится итоговое количество результатов -->
                    </div>
                    <div id="pagination">
                        <!-- Сюда будут добавляться ссылки для переключения между страницами -->
                      </div>
                      
                      

                </section>

            </section>
        </section>
    </section>

    <section id="form-bg" class="edit-container">

      <section id="form">
    <section class="for-new">

      <section class="stages">
          <input name="newStage" type="radio" value="details" id="stage-details" checked><label for="stage-details">Детали</label>
          <div class="vertical-line"></div>
          <input name="newStage" type="radio" value="sim" id="stage-sim"><label for="stage-sim">SIM - Карта</label>
          <div class="vertical-line"></div>
          <input name="newStage" type="radio" value="ts" id="stage-ts"><label for="stage-ts">Транспортное средство</label>
          <div class="vertical-line"></div>
          <input name="newStage" type="radio" value="equipment" id="stage-equipment"><label for="stage-equipment">Оборудование</label>
      </section>
    </section>
    <section id="add-new-container" class="add-new">


      <img src="../img/xmark.svg" id="close-form-btn">
      <form id="edit-form" enctype="multipart/form-data" method="post" action="/updatedevice">

      <div id="details" class="new-parameters active">

          <h1>Детали устройства</h1>
          <h2>Сперва самое необходимое</h2>

          <div class="horizontal-line"></div>

          <div class="parameters-inputs">
          <div class="parameters-input">
              <label for="parameters-plate">Номерной знак<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="plateNumber" type="text" id="parameters-plate" placeholder="Номер номерного знака" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-plateColor">Цвет номерного знака<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <select name="plateColor" id="parameters-plateColor">
                  <option value="white">Белый</option>
                  <option value="blue">Синий</option>
                  <option value="yellow">Жёлтый</option>
              </select>
          </div>
          <div class="parameters-input">
              <label for="parameters-serial">Серийный номер<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="serialNumber" type="text" id="parameters-serial" placeholder="Серийный номер устройства" required readonly>
          </div>
          <div class="parameters-input">
              <label for="parameters-channels">Количество каналов<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="channelsAmount" type="text" id="parameters-channels" placeholder="Кол-во каналов устройства" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-protocol">Протокол<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <select name="connectionProtocol" id="parameters-protocol">
                  <option value="N9M">N9M</option>
              </select>
          </div>
          <div class="parameters-input">
              <label for="parameters-ip">IP-адрес<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="IPAddress" type="text" id="parameters-ip" placeholder="IP-адрес сервера" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-group">Группа<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="deviceGroup" type="text" id="parameters-group" placeholder="Название группы" required readonly>
          </div>
          <div class="parameters-input">
              <label for="parameters-port">Порт<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="serverPort" type="text" id="parameters-port" placeholder="Порт сервера" required>
          </div>

          </div>

          <div class="horizontal-line"></div>

          <button id="continue-details" type="button">Продолжить</button>

      </div>

      <div id="sim" class="new-parameters">

          <h1>Настройки SIM-карты</h1>
          <h2>Для связи с устройством</h2>

          <div class="horizontal-line"></div>

          <div class="parameters-inputs">
          <div class="parameters-input">
              <label for="parameters-sim">Номер SIM-карты<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="sumNumber" type="text" id="parameters-sim" placeholder="Номер SIM-карты" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-sim-imei">IMEI<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="simIMEI" type="text" id="parameters-sim-imei" placeholder="IMEI SIM-карты" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-sim-imsi">IMSI<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="simIMSI" type="text" id="parameters-sim-imsi" placeholder="IMSI SIM-карты" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-sim-module">Тип сетевого модуля<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <select name="simModule" id="parameters-sim-module">
                  <option value="GPRS">GPRS</option>
                  <option value="CDMA">CDMA</option>
                  <option value="EVDO">EVDO</option>
                  <option value="WCDMA">WCDMA</option>
                  <option value="EDGE">EDGE</option>
                  <option value="TDSCDMA">TDSCDMA</option>
                  <option value="LTE-TDD">LTE-TDD</option>
                  <option value="LTE-FDD">LTE-FDD</option>
              </select>
          </div>

          </div>

          <div class="horizontal-line"></div>

          <button id="continue-sim" type="button">Продолжить</button>

      </div>

      <div id="ts" class="new-parameters">

          <h1>Детали транспортного средства</h1>
          <h2>Технические характеристики и не только</h2>

          <div class="horizontal-line"></div>

          <div class="parameters-inputs">
          <div class="parameters-input">
              <label for="parameters-trasnsport-type">Тип автомобиля<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <select name="transportType" id="parameters-trasnsport-type" onchange="truncateText(this)">
                  <option value="1">Пассажирский подвижной состав</option>
                  <option value="2">Большой автобус</option>
                  <option value="3">Средний автобус</option>
                  <option value="4">Микроавтобус</option>
                  <option value="5">Лимузин</option>
                  <option value="6">Большой спальный автобус</option>
                  <option value="7">Спальный автобус среднего размера</option>
                  <option value="8">Обычный грузовик</option>
                  <option value="9">Большой обычный грузовик</option>
                  <option value="10">Среднегабаритный обычный грузовик</option>
                  <option value="11">Маленький обычный грузовик</option>
                  <option value="12">Специальная транспортировочная машина</option>
                  <option value="13">Контейнерная тележка</option>
                  <option value="14">Большой транспортировочный автомобиль</option>
                  <option value="15">Изометрический вагон</option>
                  <option value="16">Спецтехника для перевозки грузовых автомобилей</option>
                  <option value="17">Танкер</option>
                  <option value="18">Тягач</option>
                  <option value="19">Прицеп</option>
                  <option value="20">Транспортер</option>
                  <option value="21">Другая спецтехника</option>
                  <option value="22">Автомобиль для перевозки опасных грузов</option>
                  <option value="23">Сельскохозяйственная машина</option>
              </select>
          </div>
          <div class="parameters-input">
              <label for="parameters-trasnsport-factory">Номер завода<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="transportFactory" type="text" id="parameters-trasnsport-factory" placeholder="Номер завода ТС" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-transport-strength">Несущая способность<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="transportStrength" type="text" id="parameters-transport-strength" placeholder="Несущая способность (тонны)" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-transport-engine">Номер двигателя<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="transportEngine" type="text" id="parameters-transport-engine" placeholder="Номер двигателя ТС" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-transport-stanina">Номер станины<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="transportStanina" type="text" id="parameters-transport-stanina" placeholder="Номер станины ТС" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-trasnsport-fuel">Тип топливного масла<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <select name="transportFuel" id="parameters-trasnsport-fuel">
                  <option value="gasoline">Бензин</option>
                  <option value="diesel">Дизельное топливо</option>
                  <option value="naturalGas">Природный газ</option>
                  <option value="liquefiedGas">Сжиженный газ</option>
                  <option value="electric">Электрическое</option>
                  <option value="other">Прочие</option>
              </select>
          </div>
          <div class="parameters-input">
              <div class="parameters-transport-certificate">
                  <label for="parameters-transport-certificate">Свид-ство о дорожной перевозке<span style="color: rgba(255, 69, 58, 1);">*</span></label>
                  <input name="transportCertificate" type="text" id="parameters-transport-certificate" placeholder="Номер свидетельства" required>
              </div>
          </div>
          <div class="parameters-input">
              <div class="pparameters-trasnsport-category">
                  <label for="parameters-trasnsport-category">Техническая категория<span style="color: rgba(255, 69, 58, 1);">*</span></label>
                  <select name="transportCategory" id="parameters-trasnsport-category">
                      <option value="1">Категория 1</option>
                      <option value="2">Категория 2</option>
                      <option value="3">Категория 3</option>
                      <option value="other">Не достает стандарта</option>
                  </select>
              </div>
          </div>
          <div class="parameters-input">
              <label for="parameters-transport-expire">Срок действия<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="transportExpire" type="date" id="parameters-transport-expire" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-transport-consumption">Расход топлива на 100 км<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="transportConsumption" type="text" id="parameters-transport-consumption" placeholder="Расход топлива в литрах" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-transport-province">Провинция<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="transportProvince" type="text" id="parameters-transport-province" placeholder="Провинция" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-transport-city">Город<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="transportCity" type="text" id="parameters-transport-city" placeholder="Город" required>
          </div>

          </div>

          <div class="horizontal-line"></div>

          <button id="continue-ts" type="button">Продолжить</button>

      </div>

      <div id="equipment" class="new-parameters">

          <h1>Информация о оборудовании</h1>
          <h2>Технические моменты</h2>

          <div class="horizontal-line"></div>

          <div class="parameters-inputs">
          <div class="parameters-input">
              <label for="parameters-equipment-name">Имя устройства<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="equipmentName" type="text" id="parameters-equipment-name" placeholder="Имя пользовательского устройства" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-equipment-password">Пароль устройства<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="equipmentPassword" type="text" id="parameters-equipment-password" placeholder="Пароль устройства" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-equipment-number">Номер партии<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="equipmentNumber" type="text" id="parameters-equipment-number" placeholder="Заводской номер партии" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-equipment-released">Дата выпуска<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="equipmentReleased" type="date" id="parameters-equipment-released" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-device-installer">Установщик<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="equipmentInstaller" type="text" id="parameters-device-installer" placeholder="ФИО установщика" required>
          </div>
          <div class="parameters-input">
              <label for="parameters-equipment-installed">Дата монтажа<span style="color: rgba(255, 69, 58, 1);">*</span></label>
              <input name="equipmentInstalled" type="date" id="parameters-equipment-installed" required>
          </div>

              <label for="parameters-device-description">Внешнее описание</label>
              <input name="equipmentDescription" type="text" id="parameters-device-description" placeholder="Внешнее описание ">

          </div>

          <div class="horizontal-line"></div>

          <button type="button" id="send-form">Сохранить</button>

      </div>

      </form>

    </section>
  </section>
  </section>

    <script>
      const devices = [
  {{#each Registrars}}
  {
    id: "{{this.id}}",
    serial: "{{this.serial}}",
    status: "{{this.status}}",
    name: "{{this.name}}",
    group: "{{this.group}}",
    plate: "{{this.plate}}",
    sim: "{{this.sim}}",
    ip: "{{this.ip}}",
    port: "{{this.port}}",
  },
  {{/each}}
];
    </script>

    <script src="../scripts/table.js"></script>
    <script src="../scripts/jquery.min.js"></script>
    <script src="https://rawgit.com/RobinHerbots/Inputmask/5.x/dist/jquery.inputmask.js"></script>
    <script>
      $(document).ready(function(){

          $('#parameters-sim').inputmask({"mask": "+7 (999) 999-9999"});

      });
  </script>

    <script>
      const form = document.getElementById('edit-form');
      const sendButton = document.getElementById('send-form');

      sendButton.addEventListener('click', function(event) {
        event.preventDefault(); // Предотвращаем отправку формы по умолчанию

        const xhr = new XMLHttpRequest();
        
        xhr.open('POST', form.action, true);
        
        xhr.setRequestHeader('Content-Type', 'application/json');
        
        xhr.onload = function() {
          if (xhr.status === 200) {
            console.log('Данные устройства обновлены!');
            location.reload()
          } else {
            console.error('Ошибка отправки формы:', xhr.status);
          }
        };
        
        // Получаем данные формы для отправки
        const formData = new FormData(form);
        
        // Создаем объект с данными формы
        const data = {};
        for (const [key, value] of formData) {
          data[key] = value;
        }
        
        // Преобразуем данные в JSON
        const jsonData = JSON.stringify(data);
        
        // Отправляем данные формы
        xhr.send(jsonData);
      });
    </script>

    <script>
      // Преобразование даты в формат YYYY-MM-DD
      function formatDate(date) {
        const year = date.getFullYear();
        const month = String(date.getMonth() + 1).padStart(2, '0');
        const day = String(date.getDate()).padStart(2, '0');
        return `${year}-${month}-${day}`;
      }

      

      // Открывает popup форму
      function openForm(id) {

        var formContainer = $("#form-bg");
      var form = $("#form");

      $.ajax({
        url: "/devicedata", 
        method: "POST",
        contentType: "application/json",
        data: JSON.stringify({ id: id }),
        success: function(response) {
          // Установка значений полей формы
          $("#parameters-plate").val(response.plate);
          $("#parameters-plateColor").val(response.plate_color);
          $("#parameters-serial").val(response.serial);
          $("#parameters-channels").val(response.channels);
          $("#parameters-protocol").val(response.protocol);
          $("#parameters-ip").val(response.ip);
          $("#parameters-group").val(response.group);
          $("#parameters-port").val(response.port);
          $("#parameters-sim").val(response.sim);
          $("#parameters-sim-imei").val(response.imei);
          $("#parameters-sim-imsi").val(response.imsi);
          $("#parameters-sim-module").val(response.module);
          $("#parameters-trasnsport-type").val(response.auto);
          $("#parameters-trasnsport-factory").val(response.factory);
          $("#parameters-transport-strength").val(response.capacity);
          $("#parameters-transport-engine").val(response.engine);
          $("#parameters-transport-stanina").val(response.stanina);
          $("#parameters-trasnsport-fuel").val(response.fuel);
          $("#parameters-transport-certificate").val(response.certificate);
          $("#parameters-transport-category").val(response.category);
          $("#parameters-transport-expire").val(formatDate(new Date(response.certificate_exp)));
          $("#parameters-transport-consumption").val(response.consumption);
          $("#parameters-transport-province").val(response.region);
          $("#parameters-transport-city").val(response.city);
          $("#parameters-equipment-name").val(response.name);
          $("#parameters-equipment-password").val(response.password);
          $("#parameters-equipment-number").val(response.batch);
          $("#parameters-equipment-released").val(formatDate(new Date(response.release)));
          $("#parameters-device-installer").val(response.installer);
          $("#parameters-equipment-installed").val(formatDate(new Date(response.installation)));
          $("#parameters-device-description").val(response.description);

          activeContent = content1
          switchContent(content1);

          content2.style.opacity = 0;
          content2.style.display = "none";
          content3.style.opacity = 0;
          content3.style.display = "none";
          content4.style.opacity = 0;
          content4.style.display = "none";

          document.getElementById("stage-details").checked = true;

          // Открытие формы
          formContainer.addClass("active");
          form.addClass("form-animation");
          $("body").css("overflow", "hidden");
        },
        error: function() {
          // Обработка ошибки при запросе к серверу
          alert("Произошла ошибка при запросе к серверу.");
        }
      });
      }

      $(document).ready(function() {
      var formContainer = $("#form-bg");
      var form = $("#form");

      

      // Закрывает popup форму
      $("#close-form-btn").click(function() {
        closeForm();
      });

      // Закрывает popup форму при клике вне её области
      $(document).click(function(event) {
        if (
    !formContainer.is(event.target) &&
    formContainer.has(event.target).length === 0 &&
    formContainer.hasClass("active") &&
    !openButton.is(event.target)
  ) {
          closeForm();
        }
      });

      // Функция для закрытия формы
      function closeForm() {
        formContainer.removeClass("active");
        form.removeClass("form-animation");
        $("body").css("overflow", "auto");
      }
    });
    </script>

    <script>
        // Скрытие/Показ дополнительных меню аккаунта
        const accountMain = document.getElementById('account-main');
        const accountAdditional = document.getElementById('account-additional');
        const accountUp = document.getElementById('up');
        const accountDown = document.getElementById('down');
        accountAdditional.style.display = 'none';
        accountUp.style.display = 'none';
        
        accountMain.addEventListener('click', () => {
          if (accountAdditional.style.display === 'none') {
            accountAdditional.style.display = 'flex';
            accountUp.style.display = 'unset';
            accountDown.style.display = 'none';
          } else {
            accountAdditional.style.display = 'none';
            accountUp.style.display = 'none';
            accountDown.style.display = 'unset';
          }
        });
      </script>

      <script src="../scripts/device-form.js"></script> 

      <script>
        const checkboxes = document.querySelectorAll('.organisation .checkbox-input');

checkboxes.forEach((checkbox) => {
    applyFilterAndSearch();
  checkbox.addEventListener('change', function() {
    document.querySelector('#device-all').checked = false;
    applyFilterAndSearch();
    const devices = this.parentNode.querySelector('.area-devices');
    if (this.checked) {
      devices.style.display = 'block';

      // Активируем дочерние чекбоксы
      const childCheckboxes = devices.querySelectorAll('.device-filter');
      childCheckboxes.forEach((childCheckbox) => {
        childCheckbox.checked = true;
        applyFilterAndSearch();
      });
    } else {
      devices.style.display = 'none';
      applyFilterAndSearch();

      // Деактивируем дочерние чекбоксы
      const childCheckboxes = devices.querySelectorAll('.device-filter');
      childCheckboxes.forEach((childCheckbox) => {
        childCheckbox.checked = false;
        applyFilterAndSearch();
      });
    }

    // Деактивируем дочерние чекбоксы, если родительский чекбокс не выбран
    if (!this.checked) {
      const childCheckboxes = devices.querySelectorAll('.device-filter');
      childCheckboxes.forEach((childCheckbox) => {
        childCheckbox.checked = false;
        applyFilterAndSearch();
      });
      devices.style.display = 'none';
    }
  });
});

      </script>

      <script>

var table = document.querySelector('#deviceTable');
var tableCheckboxAll = table.querySelector('#device-all');
var tableCheckboxes = table.querySelectorAll('tbody input[type="checkbox"]');

tableCheckboxAll.addEventListener('click', function(event) {
    table = document.querySelector('#deviceTable');
    tableCheckboxes = table.querySelectorAll('tbody input[type="checkbox"]');
    if (tableCheckboxAll.checked) {
    tableCheckboxes.forEach((tableCheckbox) => {
        tableCheckbox.checked = true;
      });
    } else {
        tableCheckboxes.forEach((tableCheckbox) => {
        tableCheckbox.checked = false;
      });
    }
});

$('#deviceTable').click( function(event) {
    table = document.querySelector('#deviceTable');
    tableCheckboxes = table.querySelectorAll('tbody input[type="checkbox"]');


for (var i = 0; i < tableCheckboxes.length; i++) {
    tableCheckboxes[i].addEventListener('click', function(event) {
    for (var j = 0; j < tableCheckboxes.length; j++) {
      if (!tableCheckboxes[j].checked || tableCheckboxes[j].disabled) {
        tableCheckboxAll.checked = false;
        return;
      }
    }
    tableCheckboxAll.checked = true;
  });
}
});

      </script>
      
    
</body>
</html>