landing.html 9.1 KB
<!DOCTYPE html>
<html lang="es">
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <title>SIGEMWEB - Dashboard</title>

  <!-- Google Font: Source Sans Pro -->
  <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Source+Sans+Pro:300,400,400i,700&display=fallback">
  <!-- Font Awesome -->
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.4/css/all.min.css">
  <!-- Theme style -->
  <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/admin-lte@3.2/dist/css/adminlte.min.css">
  <style>
      .content-wrapper { padding: 0; margin-left: 250px; height: calc(100vh - 57px); overflow: hidden; }
      iframe#main-iframe { width: 100%; height: 100%; border: none; }
      .brand-link { background-color: #0056b3 !important; color: white !important; font-weight: bold;}
      .main-header { background-color: #006ddb !important; border-bottom: none; }
      .navbar-light .navbar-nav .nav-link { color: white; font-weight: 600;}
      /* Treeview in popup */
      .modal-treeview ul { list-style-type: none; padding-left: 20px; }
      .modal-treeview li { margin-bottom: 5px; cursor: default;}
      .modal-treeview li span { font-size: 14px; font-weight: 500; }
      .modal-treeview li span.clickable:hover { color: #0056b3; cursor: pointer; font-weight: bold; }
  </style>
</head>
<body class="hold-transition sidebar-mini layout-fixed">
<div class="wrapper">

  <!-- Navbar -->
  <nav class="main-header navbar navbar-expand navbar-light">
    <!-- Left navbar links -->
    <ul class="navbar-nav">
      <li class="nav-item">
        <a class="nav-link" data-widget="pushmenu" href="#" role="button"><i class="fas fa-bars"></i></a>
      </li>
      <li class="nav-item d-none d-sm-inline-block">
        <span class="nav-link" style="color: white; font-size: 18px; margin-left:10px;">Municipalidad de <span id="nav-entidad-text" style="font-weight: 800;">...</span>  <span style="font-size: 14px; font-weight: 300;">¡Emergente y Sostenible!</span></span>
      </li>
    </ul>

    <!-- Right navbar links -->
    <ul class="navbar-nav ml-auto">
      <li class="nav-item dropdown">
        <a class="nav-link" data-toggle="dropdown" href="#" style="color: white;">
          <i class="far fa-user mr-2"></i> <span id="nav-user-text">Cargando...</span>
        </a>
        <div class="dropdown-menu dropdown-menu-lg dropdown-menu-right">
          <a href="#" class="dropdown-item" onclick="cerrarSesion()">
            <i class="fas fa-sign-out-alt mr-2 text-danger"></i> Cerrar Sesión
          </a>
        </div>
      </li>
    </ul>
  </nav>
  <!-- /.navbar -->

  <!-- Main Sidebar Container -->
  <aside class="main-sidebar sidebar-dark-primary elevation-4">
    <!-- Brand Logo -->
    <a href="#" class="brand-link text-center mb-2">
      <span class="brand-text"><b>SIGEM</b>WEB</span>
    </a>

    <!-- Sidebar Menu -->
    <nav class="mt-2">
      <ul class="nav nav-pills nav-sidebar flex-column text-sm" data-widget="treeview" role="menu" data-accordion="false">
        
        <li class="nav-item">
          <a href="#" class="nav-link" onclick="loadContent('/gis-geoserver/widgets')">
            <i class="nav-icon fas fa-tachometer-alt"></i>
            <p>Dashboard <span class="right badge badge-primary">New</span></p>
          </a>
        </li>

        <!-- Legacy Tree -->
        <li class="nav-item menu-open">
          <a href="#" class="nav-link active" style="background-color: #343a40;">
            <i class="nav-icon fas fa-chart-line"></i>
            <p>
              Control de Gestión
              <i class="right fas fa-angle-left"></i>
            </p>
          </a>
          <ul class="nav nav-treeview">
            <li class="nav-item menu-open">
              <a href="#" class="nav-link">
                <i class="far fa-dot-circle nav-icon"></i>
                <p>Mapas <i class="right fas fa-angle-left"></i></p>
              </a>
              <ul class="nav nav-treeview" style="margin-left: 10px;">
                <li class="nav-item menu-open">
                  <a href="#" class="nav-link">
                    <i class="fas fa-map nav-icon text-info"></i>
                    <p>Tributarios <i class="right fas fa-angle-left"></i></p>
                  </a>
                  <ul class="nav nav-treeview" style="margin-left: 10px;">
                    <li class="nav-item">
                      <a href="#" class="nav-link" data-toggle="modal" data-target="#modalMorosidad">
                        <i class="fas fa-layer-group nav-icon text-warning"></i>
                        <p>Mapa Morosidad/Pago</p>
                      </a>
                    </li>
                  </ul>
                </li>
              </ul>
            </li>
          </ul>
        </li>

        <!-- Dummy Options -->
        <li class="nav-header">OTRAS OPCIONES</li>
        <li class="nav-item">
          <a href="#" class="nav-link" onclick="notImplemented()">
            <i class="nav-icon fas fa-file-invoice-dollar text-muted"></i>
            <p>Liquidaciones</p>
          </a>
        </li>
        <li class="nav-item">
          <a href="#" class="nav-link" onclick="notImplemented()">
            <i class="nav-icon fas fa-users text-muted"></i>
            <p>Contribuyentes</p>
          </a>
        </li>

      </ul>
    </nav>
    <!-- /.sidebar-menu -->
  </aside>

  <!-- Content Wrapper. Contains page content -->
  <div class="content-wrapper">
    <iframe id="main-iframe" src="/gis-geoserver/widgets"></iframe>
  </div>

  <!-- Main Footer -->
  <footer class="main-footer" style="padding: 5px; font-size: 12px;">
    <strong>Sistema de Información Geográfica Municipal.</strong>
    Todos los derechos reservados.
  </footer>
</div>
<!-- ./wrapper -->

<!-- Modal Pop-up para Selección de Mapa (Exactamente como el legado) -->
<div class="modal fade" id="modalMorosidad" tabindex="-1" role="dialog" aria-hidden="true">
  <div class="modal-dialog modal-sm" role="document" style="margin-top: 15vh;">
    <div class="modal-content shadow-lg" style="border: 1px solid #17a2b8;">
      <div class="modal-header bg-info" style="padding: 10px;">
        <h6 class="modal-title" style="font-weight: bold;"><i class="fas fa-filter"></i> Selección Capas Geo</h6>
        <button type="button" class="close text-white" data-dismiss="modal" aria-label="Close">
          <span aria-hidden="true">&times;</span>
        </button>
      </div>
      <div class="modal-body modal-treeview">
        <ul>
          <li><i class="fas fa-minus-square mr-1 text-secondary"></i> <span>MAPA DE MOROSIDAD</span>
            <ul>
              <li><i class="fas fa-plus-square mr-1 text-secondary"></i> <span>IMPUESTOS ADEUDADOS</span>
                <ul>
                  <li><i class="fas fa-plus mr-1 text-muted"></i> <span class="clickable" onclick="notImplemented()">Impuesto Inmobiliario</span></li>
                  <li><i class="fas fa-plus mr-1 text-muted"></i> <span class="clickable" onclick="notImplemented()">Patente Comercial</span></li>
                  <li><i class="fas fa-plus-square mr-1 text-secondary"></i> <span>Todos</span>
                    <ul>
                      <li><i class="far fa-window-restore mr-1 text-muted"></i> <span class="clickable" onclick="notImplemented()">POR TOTAL</span></li>
                      <li><i class="far fa-clock mr-1 text-muted"></i> <span class="text-primary font-weight-bold clickable" onclick="loadMap()">ULTIMO PAGO / TODOS</span></li>
                    </ul>
                  </li>
                </ul>
              </li>
              <li><i class="fas fa-plus-square mr-1 text-muted"></i> <span class="clickable" onclick="notImplemented()">IMPUESTOS PAGADOS</span></li>
            </ul>
          </li>
        </ul>
      </div>
    </div>
  </div>
</div>

<!-- jQuery -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<!-- Bootstrap 4 -->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@4.6.2/dist/js/bootstrap.bundle.min.js"></script>
<!-- AdminLTE App -->
<script src="https://cdn.jsdelivr.net/npm/admin-lte@3.2/dist/js/adminlte.min.js"></script>

<script>
    // Recuperar datos de sesión
    const token = localStorage.getItem('jwt');
    const userName = localStorage.getItem('user_name');
    const entidad = localStorage.getItem('entidad');

    if (!token) {
        window.location.href = "/gis-geoserver/login";
    }

    document.getElementById('nav-user-text').innerText = userName || 'Operador Local';
    document.getElementById('nav-entidad-text').innerText = entidad || 'N/D';

    function notImplemented() {
        alert("OPCIÓN NO IMPLEMENTADA");
    }

    function loadContent(url) {
        document.getElementById('main-iframe').src = url;
    }

    function loadMap() {
        // Cierra el modal de forma programática usando jQuery de Bootstrap
        $('#modalMorosidad').modal('hide');
        // Redirige el iframe central hacia nuestro impecable mapas.html
        loadContent('/gis-geoserver/mapas');
    }

    function cerrarSesion() {
        localStorage.clear();
        window.location.href = "/gis-geoserver/login";
    }
</script>
</body>
</html>
GitLab Appliance - Powered by TurnKey Linux