<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Haxxnet Compose Viewer</title> <link rel="shortcut icon" href="" /> <!-- Bootstrap CSS --> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" integrity="sha512-t4GWSVZO1eC8BM339Xd7Uphw5s17a86tIZIj8qRxhnKub6WoyhnrxeCIMeAqBPgdZGlCcG2PrZjMc+Wr78+5Xg==" crossorigin="anonymous"> <!-- Dark Mode CSS --> <style> body { background-color: #333; color: #fff; min-height: 100vh; display: flex; flex-direction: column; } .container { flex: 1; } .project-tile { border: 1px solid #555; border-radius: 10px; padding: 10px; margin: 10px; text-align: center; background-color: #444; cursor: pointer; } .project-tile img { max-width: 50px; max-height: 50px; margin-bottom: 10px; } #searchBar { width: 310px; margin: 10px auto; padding: 10px; border-radius: 5px; border: none; background-color: transparent; color: #fff; box-sizing: border-box; } #repoContent .project-tile { width: 20%; /* Set width to 20% for 5 tiles in a row by default */ } /* Responsive adjustment for small screens */ @media (max-width: 576px) { #repoContent .project-tile { width: 40%; /* Set width to 45% for 2 tiles in a row on small screens */ } } </style> </head> <body class="container mt-5"> <div class="container"> <a target="_blank" href="https://github.com/Haxxnet/Compose-Examples" class="d-flex justify-content-center"> <img width="80px" src="https://avatars.githubusercontent.com/u/98923398?s=200&v=4" alt="Haxxnet Avatar"> </a><br> <div align="center" width="100%"> <h1>Awesome Docker Compose Examples</h1> <p>Various Docker Compose examples of selfhosted FOSS and proprietary projects.</p> <img src="https://img.shields.io/github/stars/Haxxnet/Compose-Examples.svg?style=social&label=Star" /> | <img src="https://img.shields.io/github/forks/Haxxnet/Compose-Examples.svg?style=social&label=Fork" /> | <img src="https://img.shields.io/github/watchers/Haxxnet/Compose-Examples.svg?style=social&label=Watch" /><p> <img src="https://img.shields.io/github/directory-file-count/Haxxnet/Compose-Examples/examples?label=Compose%20Examples&style=for-the-badge.svg&color=blue" /> <img src="https://img.shields.io/badge/maintainer-LRVT-red" /><p> </div> <div class="text-center mt-3"> <button class="btn btn-primary" onclick="randomProject()">Random Project</button> <button class="btn btn-danger" onclick="clearAndReload()">Clear Search</button> </div> <div id="searchBar" class="text-center"> <input type="text" id="searchInput" class="form-control" placeholder="Search by project name..."> </div> <div id="repoContent" class="row justify-content-center"></div> </div> <!-- jQuery and Bootstrap JS --> <script src="https://code.jquery.com/jquery-3.6.4.min.js" integrity="sha512-pumBsjNRGGqkPzKHndZMaAG+bir374sORyzM3uulLV14lN5LyykqNk8eEeUlUkB3U0M4FApyaHraT65ihJhDpQ==" crossorigin="anonymous"></script> <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js" integrity="sha512-VK2zcvntEufaimc+efOYi622VN5ZacdnufnmX7zIhCPmjhKnOi9ZDMtg1/ug5l183f19gG1/cBstPO4D8N/Img==" crossorigin="anonymous"></script> <!-- Custom JavaScript --> <script> var apiUrl = 'https://api.github.com/repos/Haxxnet/Compose-Examples/contents/examples'; var data; // Define the data variable globally var dockericon = 'https://cdn.jsdelivr.net/gh/walkxcode/dashboard-icons/png/docker.png'; function clearAndReload() { // Clear the search input field document.getElementById('searchInput').value = ''; // Reload all tiles (assuming loadProjects() is your initial load function) loadProjects(); } function loadProjects() { $.get(apiUrl, function (data) { data.forEach(function (project) { if (project.type === 'dir') { var projectName = project.name; var imageUrl = `https://cdn.jsdelivr.net/gh/walkxcode/dashboard-icons/png/${projectName}.png`; var projectTile = $('<div class="col-md-2 project-tile">' + '<img src="' + imageUrl + '" onerror="this.src=\'' + dockericon + '\'" alt="Icon">' + '<h5>' + project.name + '</h5>' + '</div>'); projectTile.on('click', function () { window.open(project.html_url, '_blank'); }); $('#repoContent').append(projectTile); } }); }); } // Initial load $.get(apiUrl, function (responseData) { data = responseData; loadProjects(); // Call the function to load projects after data is available }); // Search functionality $('#searchInput').on('input', function () { var searchTerm = $(this).val().toLowerCase(); // Clear existing content $('#repoContent').empty(); // Reload projects based on the search term data.forEach(function (project) { if (project.type === 'dir' && project.name.toLowerCase().includes(searchTerm)) { var projectName = project.name; var imageUrl = `https://cdn.jsdelivr.net/gh/walkxcode/dashboard-icons/png/${projectName}.png`; var projectTile = $('<div class="col-md-2 project-tile">' + '<img src="' + imageUrl + '" onerror="this.src=\'' + dockericon + '\'" alt="Icon">' + '<h5>' + project.name + '</h5>' + '</div>'); projectTile.on('click', function () { window.open(project.html_url, '_blank'); }); $('#repoContent').append(projectTile); } }); }); // Function to select a random project name and fill the search input function randomProject() { // Get a random project index var randomIndex = Math.floor(Math.random() * data.length); var randomProject = data[randomIndex]; // Fill the search input with the random project name $('#searchInput').val(randomProject.name); // Trigger the input event to initiate the search $('#searchInput').trigger('input'); } </script> </body> </html>