319 lines
12 KiB
HTML
319 lines
12 KiB
HTML
<!doctype html>
|
|
<html>
|
|
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<title>Kaj Forney -- GIMM 285 CRUD API Project</title>
|
|
<meta name="description" content="">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
|
|
<link rel="manifest" href="site.webmanifest">
|
|
<link rel="apple-touch-icon" href="icon.png">
|
|
|
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.3/dist/css/bootstrap.min.css" rel="stylesheet"
|
|
integrity="sha384-rbsA2VBKQhggwzxH7pPCaAqO46MgnOM80zW1RWuH61DGLwZJEdK2Kadq2F9CUG65" crossorigin="anonymous">
|
|
<link rel="stylesheet" href="css/normalize.css">
|
|
<link rel="stylesheet" href="css/main.css">
|
|
|
|
<meta name="theme-color" content="#488ea7">
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<div id="navbar">
|
|
<nav class="navbar navbar-expand-lg navbar-dark bg-dark">
|
|
<div class="container-fluid">
|
|
<button class="navbar-toggler" type="button" data-bs-toggle="collapse"
|
|
data-bs-target="#navbarMenu" aria-controls="navbarSupportedContent"
|
|
aria-expanded="false" aria-label="Toggle navigation">
|
|
<span class="navbar-toggler-icon"></span>
|
|
</button>
|
|
<div class="collapse navbar-collapse" id="navbarMenu">
|
|
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
|
|
<li class="navbar-brand">ADMIN</li>
|
|
<li class="nav-item m-2">
|
|
<a href="viewGameData.html">View Games</a>
|
|
</li>
|
|
<li class="nav-item dropdown">
|
|
<a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button"
|
|
data-bs-toggle="dropdown" aria-expanded="false">
|
|
Add
|
|
</a>
|
|
|
|
<ul class="dropdown-menu bg-dark" aria-labelledby="navbarDropdown">
|
|
<li>
|
|
<a class="dropdown-item" href="insert.html">Add Game</a>
|
|
</li>
|
|
<li>
|
|
<a class="dropdown-item" href="insertDeveloper.html">Add Developer</a>
|
|
</li>
|
|
<li>
|
|
<a class="dropdown-item" href="insertPublisher.html">Add Publisher</a>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<div class="nav-item m-2 align-content-end">
|
|
<a href="index.html">Exit Admin View</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</nav>
|
|
</div>
|
|
|
|
<div id="header" class="container">
|
|
<h1>View Game Data</h1>
|
|
<hr/>
|
|
</div>
|
|
|
|
<div id="form">
|
|
<div class="container">
|
|
<div class="row mb-3">
|
|
<div class="col">
|
|
<label>Application ID</label>
|
|
</div>
|
|
<div class="col">
|
|
<input id="appID" type="text"/>
|
|
</div>
|
|
<div class="col"></div>
|
|
</div>
|
|
|
|
<div class="row mb-3">
|
|
<div class="col">
|
|
<label>Title</label>
|
|
</div>
|
|
<div class="col">
|
|
<input id="title" type="text"/>
|
|
</div>
|
|
<div class="col"></div>
|
|
</div>
|
|
|
|
<div class="row mb-3">
|
|
<div class="col">
|
|
<label>Developer</label>
|
|
</div>
|
|
<div class="col">
|
|
<input id="developer" type="text"/>
|
|
</div>
|
|
<div class="col"></div>
|
|
</div>
|
|
|
|
<div class="row mb-3">
|
|
<div class="col">
|
|
<label>Publisher</label>
|
|
</div>
|
|
<div class="col">
|
|
<input id="publisher" type="text"/>
|
|
</div>
|
|
<div class="col"></div>
|
|
</div>
|
|
|
|
<div class="row mb-3">
|
|
<div class="col">
|
|
<label>Release Date</label>
|
|
</div>
|
|
<div class="col">
|
|
<input id="releaseDate" type="date"/>
|
|
</div>
|
|
<div class="col"></div>
|
|
</div>
|
|
|
|
<div class="row mb-3">
|
|
<div class="col">
|
|
<label>Supported OSes</label>
|
|
</div>
|
|
<div class="col">
|
|
<div class="row">
|
|
<div class="col">
|
|
<span>Windows</span>
|
|
<input id="win" type="checkbox"/>
|
|
</div>
|
|
<div class="col">
|
|
<span>MacOS</span>
|
|
<input id="mac" type="checkbox"/>
|
|
</div>
|
|
<div class="col">
|
|
<span>Linux</span>
|
|
<input id="linux" type="checkbox"/>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col"></div>
|
|
</div>
|
|
|
|
<hr/>
|
|
|
|
<div class="row mb-3">
|
|
<div class="col">
|
|
<label>Limit Number of Results to:</label>
|
|
</div>
|
|
<div class="col">
|
|
<input id="limitNumber" type="text"/>
|
|
</div>
|
|
<div class="col"></div>
|
|
</div>
|
|
|
|
<div class="row mb-3">
|
|
<div class="col">
|
|
<label>Order by:</label>
|
|
</div>
|
|
<div class="col">
|
|
<select id="orderBy">
|
|
<option value="ASC">Ascending</option>
|
|
<option value="DESC">Descending</option>
|
|
</select>
|
|
</div>
|
|
<div class="col"></div>
|
|
</div>
|
|
|
|
<div class="row mb-3">
|
|
<div class="col align-content-center">
|
|
<input id="submitButton" type="submit"/>
|
|
</div>
|
|
</div>
|
|
<hr/>
|
|
</div>
|
|
|
|
|
|
<div id="outputTable" class="container overflow"></div>
|
|
|
|
</div>
|
|
|
|
<footer id="footer">
|
|
<p>Page created by <a href="https://lunarpenguin.net/">Kaj Forney</a>, as work for class (GIMM 285).</p>
|
|
</footer>
|
|
|
|
<script src="js/vendor/modernizr-3.11.2.min.js"></script>
|
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.3/dist/js/bootstrap.bundle.min.js"
|
|
integrity="sha384-kenU1KFdBIe4zVF0s0G1M5b4hcpxyD9F7jL+jjXkk+Q2h455rYXK/7HAuoJl+0I4"
|
|
crossorigin="anonymous" defer></script>
|
|
|
|
<script>
|
|
const isEmpty = (obj) => Object.keys(obj).length === 0;
|
|
|
|
document.getElementById('submitButton').addEventListener('click', (event) => {
|
|
//const formData = new FormData();
|
|
const getParameters = {};
|
|
|
|
if (document.getElementById('appID').value.length !== 0) {
|
|
//formData.append('appID', document.getElementById('appID').value);
|
|
getParameters.appID = document.getElementById('appID').value;
|
|
}
|
|
if (document.getElementById('title').value.length !== 0) {
|
|
//formData.append('title', document.getElementById('title').value);
|
|
getParameters.title = document.getElementById('title').value;
|
|
}
|
|
if (document.getElementById('developer').value.length !== 0) {
|
|
//formData.append('developer', document.getElementById('developer').value);
|
|
getParameters.developer = document.getElementById('developer').value;
|
|
}
|
|
if (document.getElementById('publisher').value.length !== 0) {
|
|
//formData.append('publisher', document.getElementById('publisher').value);
|
|
getParameters.publisher = document.getElementById('publisher').value;
|
|
}
|
|
if (document.getElementById('releaseDate').value.length !== 0) {
|
|
//formData.append('releaseDate', document.getElementById('releaseDate').value);
|
|
getParameters.releaseDate = document.getElementById('releaseDate').value;
|
|
}
|
|
if (document.querySelector('#win:checked')) {
|
|
//formData.append('win', 1);
|
|
getParameters.win = 1;
|
|
}
|
|
if (document.querySelector('#mac:checked')) {
|
|
//formData.append('mac', 1);
|
|
getParameters.mac = 1;
|
|
}
|
|
if (document.querySelector('#linux:checked')) {
|
|
//formData.append('linux', 1);
|
|
getParameters.linux = 1;
|
|
}
|
|
if (document.getElementById('limitNumber').value.length !== 0) {
|
|
//formData.append('limitNumber', document.getElementById('limitNumber').value);
|
|
getParameters.limitNumber = document.getElementById('limitNumber').value;
|
|
}
|
|
if (document.getElementById('orderBy').value.length !== 0) {
|
|
//formData.append('orderBy', document.getElementById('orderBy').value);
|
|
getParameters.orderBy = document.getElementById('orderBy').value;
|
|
}
|
|
|
|
//Settings for FETCH API request
|
|
let fetchSettings = {
|
|
method: 'GET'
|
|
};
|
|
|
|
//Send FETCH API request
|
|
fetch("http://localhost:8787/games" + (!isEmpty(getParameters) ? '?' + new URLSearchParams(getParameters) : ''), fetchSettings)
|
|
.then((response) => {
|
|
return new Promise((resolve) => response.json()
|
|
.then((json) => resolve({
|
|
status: response.status,
|
|
json,
|
|
})
|
|
));
|
|
})
|
|
.then(({status, json}) => {
|
|
if (status === 200) {
|
|
let displayTable = '<table>' +
|
|
'<thead>' +
|
|
'<tr>' +
|
|
'<th>Edit Game</th>' +
|
|
'<th>Delete Game</th>' +
|
|
'<th>AppID</th>' +
|
|
'<th>Title</th>' +
|
|
'<th>Developer</th>' +
|
|
'<th>Publisher</th>' +
|
|
'<th>Release Date</th> ' +
|
|
'<th>Supported OSes</th>' +
|
|
'<th>Summary</th>' +
|
|
'<th>Cover Art</th>' +
|
|
'</tr>' +
|
|
'</thead>' +
|
|
'<tbody>';
|
|
|
|
function osSupport(win, mac, lnx) {
|
|
let osString = "";
|
|
if (win == 1) {
|
|
osString += "Windows, "
|
|
}
|
|
;
|
|
if (mac == 1) {
|
|
osString += "Mac, "
|
|
}
|
|
;
|
|
if (lnx == 1) {
|
|
osString += "Linux"
|
|
}
|
|
;
|
|
return osString;
|
|
}
|
|
|
|
if (typeof json.data !== 'undefined') {
|
|
for (row of json.data) {
|
|
displayTable += '<tr>' +
|
|
'<td> <a href="edit.html?id=' + row.appID.toString() + '">Edit</a></td>' +
|
|
'<td> <a href="delete.html?id=' + row.appID.toString() + '">Delete</a></td>' +
|
|
'<td>' + row.appID + '</td>' +
|
|
'<td>' + row.title + '</td>' +
|
|
'<td>' + row.developer + '</td>' +
|
|
'<td>' + row.publisher + '</td>' +
|
|
'<td>' + new Date(row.releaseDate).toDateString() + '</td>' +
|
|
'<td>' + osSupport(row.win.toString(), row.mac.toString(), row.linux.toString()) + '</td>' +
|
|
'<td>' + row.summary + '</td>' +
|
|
'<td> <img class="tableCoverArt" src="http://localhost:8787/images/' + row.coverArt + '"> </td>' +
|
|
'</tr>';
|
|
}
|
|
}
|
|
displayTable += '</tbody></table>';
|
|
document.getElementById('outputTable').innerHTML = displayTable;
|
|
}
|
|
})
|
|
.catch(error => {
|
|
console.error('Error:', error);
|
|
});
|
|
return;
|
|
});
|
|
</script>
|
|
|
|
</body>
|
|
|
|
</html>
|