mirror of
https://github.com/Haxxnet/Compose-Examples
synced 2024-12-18 08:10:23 +00:00
9b067d9a4d
change background color to display some greyish icons properly
175 lines
9.0 KiB
HTML
175 lines
9.0 KiB
HTML
<!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: #2d2c2c;
|
|
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>
|