<!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>
        <img src="../img/argus.png">
        <h1>Аргус</h1>
        <h2><span>/</span> {{Organisation}}</h2>
    </header>

    <section class="account-info">
      <div id="account-main">
          <img id="person" src="../img/person.svg">
          <span>{{User}}</span>
          <img id="down" src="../img/down.svg">
          <img id="up" src="../img/up.svg">
      </div>
      <a href="/logout"><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><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 href="https://forms.yandex.ru/cloud/6515ecda3e9d08f17262c332/" target="_blank">
          <div><img src="../img/bug.svg">Собщить об ошибке</div>
      </a>
        <a class="admin-panel" href="/admin">
          <div class="selected"><img src="../img/keyboard.svg">Админка</div>
        </a>
        <a class="settings" href="/settings">
            <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}}

      <section style="display: none;" class="dberror" id="addInformation" >
        <div class="erorr-container">
          <div id="loader" class="loader">
            <div class="square" id="sq1"></div>
            <div class="square" id="sq2"></div>
            <div class="square" id="sq3"></div>
            <div class="square" id="sq4"></div>
            <div class="square" id="sq5"></div>
            <div class="square" id="sq6"></div>
            <div class="square" id="sq7"></div>
            <div class="square" id="sq8"></div>
            <div class="square" id="sq9"></div>
          </div>
          <svg id="success-mark" style="display: none;" xmlns="http://www.w3.org/2000/svg" width="108" height="108" fill="none" viewBox="0 0 108 108">
            <g clip-path="url(#a)">
              <path fill="#8086F9" fill-opacity=".85" d="M54 107.947c29.541 0 54-24.5 54-53.973C108 24.447 83.488 0 53.947 0 24.459 0 0 24.447 0 53.974c0 29.474 24.512 53.973 54 53.973Zm0-8.995c-24.988 0-44.947-20.002-44.947-44.978 0-24.976 19.906-44.978 44.894-44.978S99 28.998 99 53.974c0 24.976-20.012 44.978-45 44.978Zm-5.824-19.844c1.747 0 3.23-.846 4.289-2.487l24.194-38.046c.582-1.058 1.27-2.222 1.27-3.386 0-2.382-2.117-3.916-4.341-3.916-1.323 0-2.647.847-3.653 2.381l-21.97 35.241-10.43-13.493c-1.27-1.693-2.435-2.116-3.917-2.116-2.277 0-4.077 1.852-4.077 4.18 0 1.164.477 2.276 1.218 3.28l12.917 15.875c1.324 1.747 2.753 2.487 4.5 2.487Z"/>
            </g>
            <defs>
              <clipPath id="a">
                <path fill="#fff" d="M0 0h108v108H0z"/>
              </clipPath>
            </defs>
          </svg>
          
                <h1>Добавление пользователя</h1> <br>
                <span id="status">Пожалуйста, подождите</span>
                <button id="closeButton" style="display: none;" onclick="hideMessage()">Закрыть</button>
        </div>
    </section>
  
  

        
        <nav>
            <a class="selected" href="/admin">Пользователи</a>
            <a href="/admin/organisation">Организация</a>
        </nav>
        <section class="bg">
            <section id="content" class="content">

              <input id="table-search" class="search admin-search" type="text" placeholder="Поиск по имени, почте, номеру телефона или ID">
              <button class="button-purple add-user" onclick="addUser();">Добавить пользователя</button>

              <table id="adminTable">
                <thead>
                  <tr>
                    <th>Имя</th>
                    <th>ID</th>
                    <th>Почта</th>
                    <th>Номер телефона</th>
                    <th>Дата добавления</th>
                    <th></th>
                  </tr>
                </thead>
                <tbody>
                  <!-- Сюда будут добавляться строки таблицы -->
                </tbody>
              </table>

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

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

      <section class="add-user-form" id="form">
        <h1>Добавить пользователя</h1>
        <img src="../img/xmark.svg" id="close-form-btn">


        <form id="add-user-form">
        <div class="parameters-input">
          <label for="user-name">Имя<span style="color: rgba(255, 69, 58, 1);">*</span></label>
          <input name="name" type="text" id="user-name" placeholder="Имя пользователя" required>
        </div>
        <div class="parameters-input">
          <label for="user-surname">Фамилия<span style="color: rgba(255, 69, 58, 1);">*</span></label>
          <input name="surname" type="text" id="user-surname" placeholder="Фамилия пользователя" required>
        </div>
        <div class="parameters-input">
          <label for="user-email">Email<span style="color: rgba(255, 69, 58, 1);">*</span></label>
          <input name="email" type="text" id="user-email" placeholder="Email пользователя" required>
        </div>
        <div class="parameters-input">
          <label for="user-phone">Номер телефона<span style="color: rgba(255, 69, 58, 1);">*</span></label>
          <input name="phone" type="text" id="user-phone" placeholder="Номер телефона пользователя" required>
        </div>
        <div class="parameters-input">
          <label for="user-password">Пароль<span style="color: rgba(255, 69, 58, 1);">*</span></label>
          <input name="password" type="text" id="user-password" placeholder="Пароль пользователя" required>
        </div>
        <div class="horizontal-line"></div>

        <button id="user-add" type="submit">Добавить</button>
      </form>
      </section>

    </section>

    <section style="display: none;" class="dberror" id="deleteConfirmation">
      <div class="erorr-container">
        <img src="../img/warning.svg"> <br>
        <h1>Удаление водителя </h1> <br>
        <span>Вы уверены что хотите удалить <span id="driverDeleteInfo"></span>?</span>
        <div class="buttons">
        <button id="deleteCancel" onclick="closeDeletion();" style="display: inline-block; background-color: white; color: rgba(0, 0, 0, 0.7); margin-right: 5px;" type="button">Отменить</button>
        <button id="deleteDriver" style="display: inline-block;" type="button">Подтвердить</button>
      </div>
      </div>
    </section>



    <script>
      const users = [
  {{#each Users}}
  {
    id: "{{this.id}}",
    name: "{{this.name}}",
    surname: "{{this.surname}}",
    phone: "{{this.phone}}",
    email: "{{this.email}}",
    date: "{{this.added}}",
  },
  {{/each}}
];
    </script>

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

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

      });
  </script>

    <script>
      var formContainer = $("#form-bg");
      var fform = $("#form");

      function closeForm() {
        formContainer.removeClass("active");
        fform.removeClass("form-animation");
        $("body").css("overflow", "auto");
      }

      document.addEventListener("DOMContentLoaded", function () {
        const form = document.getElementById("add-user-form");
    
        form.addEventListener("submit", function (event) {
          event.preventDefault();

          const deleteConfirmation = document.getElementById("addInformation");
        const loader = document.getElementById("loader");
        const status = document.getElementById("status");
        const closeButton = document.getElementById("closeButton");
        const mark = document.getElementById("success-mark");

        loader.style.display = "block";
        closeButton.style.display = "none";
        deleteConfirmation.style.display = "flex";
        mark.style.display = "none";
    
          const formData = new FormData(form);

                const jsonObject = {};
                formData.forEach((value, key) => {
                    jsonObject[key] = value;
                });
                const jsonData = JSON.stringify(jsonObject);

                closeForm();
                form.reset();

                fetch("/add-user", {
                    method: "POST",
                    headers: {
                        "Content-Type": "application/json"
                    },
                    body: jsonData,
                })
            .then((response) => response.json())
            .then((data) => {
              showMessage("Пользователь успешно добавлен", true);
            })
            .catch((error) => {
              showMessage("Не удалось добавить пользователя", false);
              console.error("Ошибка:", error);
            });
        });
      });
    </script>

    <script>
      
      function addUser() {
        var formContainer = $("#form-bg");
        var form = $("#form");
        formContainer.addClass("active");
        form.addClass("form-animation");
        $("body").css("overflow", "hidden");
      }

      $(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");
      }
    });
  

    function hideMessage() {
      location.reload();
        const deleteConfirmation = document.getElementById("addInformation");
        deleteConfirmation.style.display = "none";
    }

    function showMessage(messageText, isSuccess) {
        const loader = document.getElementById("loader");
        const status = document.getElementById("status");
        const closeButton = document.getElementById("closeButton");
        const mark = document.getElementById("success-mark");

        loader.style.display = "none";
        status.textContent = messageText;
        if (isSuccess) {
            mark.style.display = "block";
            status.style.color = "green"; 
        } else {
            status.style.color = "red"; 
        }
        closeButton.style.display = "block";
    }



    </script>

<script>
  function deleteUser(id) {

  var deleteConfirmation = $("#deleteConfirmation");

  $.ajax({
    url: "/userdata", 
    method: "POST",
    contentType: "application/json",
    data: JSON.stringify({ id: id }),
    success: function(response) {
      // Установка значений полей формы
      $("#driverDeleteInfo").html(response.name + " " + response.surname);
      document.getElementById('deleteDriver').setAttribute("onclick", `confirmDelete(${response.id})`);


      document.getElementById('deleteConfirmation').style.display = "flex";

      $("body").css("overflow", "hidden");
      },
      error: function() {
        // Обработка ошибки при запросе к серверу
        alert("Произошла ошибка при запросе к серверу.");
      }
  });
    
  }

  function closeDeletion() {
      document.getElementById('deleteConfirmation').style.display = "none";
    }

  function confirmDelete(id) {
  $.ajax({
    url: "/deleteuser", 
    method: "POST",
    contentType: "application/json",
    data: JSON.stringify({ id: id }),
    success: function(response) {
      location.reload();
      },
      error: function() {
        // Обработка ошибки при запросе к серверу
        alert("Произошла ошибка при запросе к серверу.");
      }
  });
    
  }
</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>
      
    
</body>
</html>