mirror of
https://github.com/driftywinds/driftywinds.github.io.git
synced 2025-12-19 11:03:32 +00:00
Add source information to app.html
This commit is contained in:
12
app.html
12
app.html
@@ -98,6 +98,18 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div id="source" class="section">
|
||||||
|
<div class="header">
|
||||||
|
<h2>Discover More From</h2>
|
||||||
|
</div>
|
||||||
|
<a class="container" target="_blank">
|
||||||
|
<div class="row">
|
||||||
|
<p class="row-title">Unknown</p>
|
||||||
|
<p class="row-subtitle">Source</p>
|
||||||
|
</div>
|
||||||
|
<i class="bi bi-arrow-up-right-square"></i>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<script src="js/shared.js"></script>
|
<script src="js/shared.js"></script>
|
||||||
<script src="js/app.js"></script>
|
<script src="js/app.js"></script>
|
||||||
|
|||||||
50
css/app.css
50
css/app.css
@@ -101,12 +101,14 @@ a {
|
|||||||
/* What's new */
|
/* What's new */
|
||||||
|
|
||||||
#whats-new,
|
#whats-new,
|
||||||
#permissions {
|
#permissions,
|
||||||
|
#source {
|
||||||
padding: 1em;
|
padding: 1em;
|
||||||
}
|
}
|
||||||
|
|
||||||
#whats-new .header,
|
#whats-new .header,
|
||||||
#permissions .header {
|
#permissions .header,
|
||||||
|
#source .header {
|
||||||
margin: 0.35em 0;
|
margin: 0.35em 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
@@ -155,4 +157,48 @@ a {
|
|||||||
#permissions .permission .description {
|
#permissions .permission .description {
|
||||||
font-size: 0.9em;
|
font-size: 0.9em;
|
||||||
opacity: 0.5;
|
opacity: 0.5;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Source */
|
||||||
|
#source {
|
||||||
|
padding-top: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#source .row {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
gap: 0.15em;
|
||||||
|
/* justify-content: space-between; */
|
||||||
|
/* margin: 1em 0; */
|
||||||
|
}
|
||||||
|
|
||||||
|
#source .container {
|
||||||
|
color: unset;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
justify-content: space-between;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
#source .row>.row-title {
|
||||||
|
font-size: 1.05em;
|
||||||
|
color: var(--app-tint-color);
|
||||||
|
}
|
||||||
|
|
||||||
|
#source .bi {
|
||||||
|
-webkit-text-stroke: 0.25px;
|
||||||
|
color: var(--app-tint-color);
|
||||||
|
}
|
||||||
|
|
||||||
|
#source .row>.row-subtitle {
|
||||||
|
color: unset;
|
||||||
|
font-size: 0.9em;
|
||||||
|
opacity: 0.5;
|
||||||
|
-webkit-line-clamp: 3;
|
||||||
|
line-clamp: 3;
|
||||||
|
display: -webkit-box;
|
||||||
|
-webkit-box-orient: vertical;
|
||||||
|
overflow: hidden;
|
||||||
|
position: relative;
|
||||||
|
word-wrap: break-word
|
||||||
}
|
}
|
||||||
42
js/app.js
42
js/app.js
@@ -140,14 +140,13 @@ function main(json) {
|
|||||||
const permissions = document.getElementById("permissions");
|
const permissions = document.getElementById("permissions");
|
||||||
|
|
||||||
// If permissions specified
|
// If permissions specified
|
||||||
if (app.permissions)
|
if (app.permissions) {
|
||||||
// Remove placeholder permission
|
// Remove placeholder permission
|
||||||
permissions.querySelector(".permission").remove();
|
permissions.querySelector(".permission").remove();
|
||||||
else return;
|
|
||||||
|
app.permissions?.forEach(permission => {
|
||||||
app.permissions?.forEach(permission => {
|
var permissionType, icon;
|
||||||
var permissionType, icon;
|
switch (permission.type) {
|
||||||
switch (permission.type) {
|
|
||||||
// AltStore-supported permissions
|
// AltStore-supported permissions
|
||||||
case "background-audio":
|
case "background-audio":
|
||||||
permissionType = "Background Audio";
|
permissionType = "Background Audio";
|
||||||
@@ -214,18 +213,27 @@ function main(json) {
|
|||||||
default:
|
default:
|
||||||
permissionType = permission.type.replaceAll("-", " ");
|
permissionType = permission.type.replaceAll("-", " ");
|
||||||
icon = "gear-wide-connected";
|
icon = "gear-wide-connected";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
permissions.insertAdjacentHTML("beforeend", `
|
||||||
|
<div class="permission">
|
||||||
|
<i class="bi-${icon}" style="color: ${tintColor};"></i>
|
||||||
|
<div class="text">
|
||||||
|
<p class="title">${permissionType}</p>
|
||||||
|
<p class="description">${permission.usageDescription ?? "No description provided."}</p>
|
||||||
|
</div>
|
||||||
|
</div>`);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
permissions.insertAdjacentHTML("beforeend", `
|
const source = document.getElementById("source");
|
||||||
<div class="permission">
|
const sourceContainer = source.querySelector(".container");
|
||||||
<i class="bi-${icon}" style="color: ${tintColor};"></i>
|
const sourceTitle = source.querySelector(".row-title");
|
||||||
<div class="text">
|
const sourceSubtitle = source.querySelector(".row-subtitle");
|
||||||
<p class="title">${permissionType}</p>
|
sourceTitle.innerText = json.name;
|
||||||
<p class="description">${permission.usageDescription ?? "No description provided."}</p>
|
sourceContainer.href = `index.html?source=${sourceURL}`;
|
||||||
</div>
|
sourceSubtitle.innerText = json.description ?? "A cool AltStore source.";
|
||||||
</div>`);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function exit() {
|
function exit() {
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
const urlSearchParams = new URLSearchParams(window.location.search);
|
const urlSearchParams = new URLSearchParams(window.location.search);
|
||||||
const sourceURL = urlSearchParams.get('source').replaceAll("+", "%2B");
|
const sourceURL = urlSearchParams.get('source')?.replaceAll("+", "%2B");
|
||||||
// https://stackoverflow.com/a/8943487
|
// https://stackoverflow.com/a/8943487
|
||||||
const urlRegex = /(\b(https?|ftp|file):\/\/[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|])/ig;
|
const urlRegex = /(\b(https?|ftp|file):\/\/[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|])/ig;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user