Avalie se é possível preparar um aplicativo web com base na planilha a anexar, onde somente serão imputados os valores que não contém fórmulas, e os demais, devem ser calculados, gerados relatórios etc. Os valores a serem imputados que constam em guias do tipo "lista", devem ser imputados em um campo txt, um do lado do outro e um abaixo do outro, ou mesmo em CSV separado por |
617a965
verified
| <html lang="pt-br"> | |
| <head> | |
| <meta charset="UTF-8"> | |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> | |
| <title>Spreadsheet Wizardry</title> | |
| <link rel="stylesheet" href="style.css"> | |
| <script src="https://cdn.tailwindcss.com"></script> | |
| <script src="https://cdn.jsdelivr.net/npm/feather-icons/dist/feather.min.js"></script> | |
| <script src="https://unpkg.com/feather-icons"></script> | |
| <script src="components/navbar.js"></script> | |
| <script src="components/sidebar.js"></script> | |
| <script src="components/footer.js"></script> | |
| </head> | |
| <body class="bg-gray-50"> | |
| <custom-navbar></custom-navbar> | |
| <div class="flex"> | |
| <custom-sidebar></custom-sidebar> | |
| <main class="flex-1 p-8"> | |
| <div class="max-w-6xl mx-auto"> | |
| <h1 class="text-3xl font-bold text-gray-800 mb-6">Spreadsheet Wizardry 🧙♂️</h1> | |
| <div class="grid grid-cols-1 md:grid-cols-2 gap-6"> | |
| <!-- Input Section --> | |
| <div class="bg-white rounded-lg shadow-md p-6"> | |
| <div class="flex items-center mb-4"> | |
| <i data-feather="upload" class="mr-2 text-blue-500"></i> | |
| <h2 class="text-xl font-semibold text-gray-700">Upload de Planilha</h2> | |
| </div> | |
| <div class="mb-4"> | |
| <label class="block text-gray-700 text-sm font-bold mb-2" for="spreadsheet"> | |
| Selecione sua planilha | |
| </label> | |
| <input type="file" id="spreadsheet" accept=".xlsx, .xls, .csv" | |
| class="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"> | |
| </div> | |
| <div class="mb-4"> | |
| <label class="block text-gray-700 text-sm font-bold mb-2" for="inputType"> | |
| Tipo de Entrada | |
| </label> | |
| <select id="inputType" class="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"> | |
| <option value="text">Texto (um abaixo do outro)</option> | |
| <option value="csv">CSV separado por |</option> | |
| </select> | |
| </div> | |
| <div id="textInputContainer" class="mb-4"> | |
| <label class="block text-gray-700 text-sm font-bold mb-2" for="manualInput"> | |
| Insira os valores (um por linha) | |
| </label> | |
| <textarea id="manualInput" rows="5" | |
| class="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"></textarea> | |
| </div> | |
| <button id="processBtn" class="w-full bg-blue-500 hover:bg-blue-600 text-white font-bold py-2 px-4 rounded-md transition duration-200 flex items-center justify-center"> | |
| <i data-feather="zap" class="mr-2"></i> Processar Dados | |
| </button> | |
| </div> | |
| <!-- Output Section --> | |
| <div class="bg-white rounded-lg shadow-md p-6"> | |
| <div class="flex items-center mb-4"> | |
| <i data-feather="bar-chart-2" class="mr-2 text-green-500"></i> | |
| <h2 class="text-xl font-semibold text-gray-700">Resultados & Relatórios</h2> | |
| </div> | |
| <div class="mb-4"> | |
| <label class="block text-gray-700 text-sm font-bold mb-2"> | |
| Visualização dos Dados | |
| </label> | |
| <div id="dataPreview" class="bg-gray-100 p-4 rounded-md h-64 overflow-auto"> | |
| <p class="text-gray-500 italic">Os dados processados aparecerão aqui...</p> | |
| </div> | |
| </div> | |
| <div class="flex space-x-2"> | |
| <button id="exportBtn" class="flex-1 bg-green-500 hover:bg-green-600 text-white font-bold py-2 px-4 rounded-md transition duration-200 flex items-center justify-center"> | |
| <i data-feather="download" class="mr-2"></i> Exportar | |
| </button> | |
| <button id="reportBtn" class="flex-1 bg-purple-500 hover:bg-purple-600 text-white font-bold py-2 px-4 rounded-md transition duration-200 flex items-center justify-center"> | |
| <i data-feather="file-text" class="mr-2"></i> Gerar Relatório | |
| </button> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Formula Section --> | |
| <div class="bg-white rounded-lg shadow-md p-6 mt-6"> | |
| <div class="flex items-center mb-4"> | |
| <i data-feather="code" class="mr-2 text-yellow-500"></i> | |
| <h2 class="text-xl font-semibold text-gray-700">Fórmulas e Cálculos</h2> | |
| </div> | |
| <div id="formulaDisplay" class="bg-gray-100 p-4 rounded-md"> | |
| <p class="text-gray-500 italic">As fórmulas serão exibidas aqui conforme os dados são processados...</p> | |
| </div> | |
| </div> | |
| </div> | |
| </main> | |
| </div> | |
| <custom-footer></custom-footer> | |
| <script src="script.js"></script> | |
| <script> | |
| feather.replace(); | |
| </script> | |
| <script src="https://huggingface.co/deepsite/deepsite-badge.js"></script> | |
| </body> | |
| </html> |