GAHHH I BROKE IT
This commit is contained in:
parent
1075e0a995
commit
85e70157ad
1 changed files with 104 additions and 94 deletions
|
@ -1,115 +1,125 @@
|
||||||
import {createSignal, onMount} from "solid-js"
|
import { createSignal, onMount } from "solid-js";
|
||||||
import {ishover} from "../App";
|
import { ishover } from "../App";
|
||||||
|
|
||||||
interface Review {
|
interface Review {
|
||||||
reviewID: number;
|
reviewID: number;
|
||||||
discordID: string;
|
discordID: string;
|
||||||
reviewText: string;
|
reviewText: string;
|
||||||
timestamp: string;
|
timestamp: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface NeoReview extends Review {
|
interface NeoReview extends Review {
|
||||||
global_name: string;
|
global_name: string;
|
||||||
username: string
|
username: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
export default function Reviews() {
|
export default function Reviews() {
|
||||||
const [reviews, setReviews] = createSignal<NeoReview[]>([]);
|
const [reviews, setReviews] = createSignal<NeoReview[]>([]);
|
||||||
onMount(() => {
|
onMount(() => {
|
||||||
fetch("https://review.exhq.dev/getreviews")
|
fetch("https://review.exhq.dev/getreviews")
|
||||||
.then(response => response.json())
|
.then((response) => response.json())
|
||||||
.then((data: Review[]) => {
|
.then((data: Review[]) => {
|
||||||
const promises = data.map(review => (
|
const promises = data.map((review) =>
|
||||||
fetch(`https://dc-lookup.spiro.exhq.dev/v1/user/${review.discordID}`)
|
fetch(`https://dc-lookup.spiro.exhq.dev/v1/user/${review.discordID}`)
|
||||||
.then(response => response.json())
|
.then((response) => response.json())
|
||||||
.then(user => ({
|
.then((user) => ({
|
||||||
...review,
|
...review,
|
||||||
global_name: user.global_name,
|
global_name: user.global_name,
|
||||||
username: user.username
|
username: user.username,
|
||||||
}))
|
})),
|
||||||
));
|
);
|
||||||
|
|
||||||
Promise.all(promises)
|
Promise.all(promises)
|
||||||
.then(yeah => {
|
.then((yeah) => {
|
||||||
setReviews(yeah);
|
setReviews(yeah);
|
||||||
})
|
})
|
||||||
.catch(error => console.error("Error fetching Discord user data:", error));
|
.catch((error) =>
|
||||||
})
|
console.error("Error fetching Discord user data:", error),
|
||||||
.catch(error => console.error("Error fetching reviews:", error));
|
);
|
||||||
});
|
})
|
||||||
|
.catch((error) => console.error("Error fetching reviews:", error));
|
||||||
|
});
|
||||||
|
|
||||||
|
return (
|
||||||
return (
|
<>
|
||||||
<>
|
<a
|
||||||
<a style={{
|
style={{
|
||||||
display: ishover() ? "inline" : "none"
|
display: ishover() ? "inline" : "none",
|
||||||
}}
|
}}
|
||||||
href="https://discord.com/oauth2/authorize?client_id=1208380910525743134&response_type=token&redirect_uri=https%3A%2F%2Fexhq.dev%2Freview%2F&scope=identify">
|
href="https://discord.com/oauth2/authorize?client_id=1208380910525743134&response_type=code&redirect_uri=https%3A%2F%2Famy.rip%2Freview%2F&scope=identify"
|
||||||
<p class="fadein">add your reviews here</p>
|
>
|
||||||
</a>
|
<p class="fadein">add your reviews here</p>
|
||||||
<h1 class="reviewheadertext">Reviews</h1>
|
</a>
|
||||||
<div
|
<h1 class="reviewheadertext">Reviews</h1>
|
||||||
class="actualreviewdiv">
|
<div class="actualreviewdiv">
|
||||||
{reviews().length > 0 ? (
|
{reviews().length > 0 ? (
|
||||||
reviews().reverse().map((review) => (
|
reviews()
|
||||||
<div>
|
.reverse()
|
||||||
<SingleReview {...review} />
|
.map((review) => (
|
||||||
</div>
|
<div>
|
||||||
))
|
<SingleReview {...review} />
|
||||||
) : (
|
</div>
|
||||||
<div>Loading reviews...</div>
|
))
|
||||||
)}
|
) : (
|
||||||
</div>
|
<div>Loading reviews...</div>
|
||||||
</>
|
)}
|
||||||
|
</div>
|
||||||
)
|
</>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export const theImager = async (id: string): Promise<string> =>
|
||||||
export const theImager = async (id: string): Promise<string> => (await fetch(`https://dc-lookup.spiro.exhq.dev/v1/user/${id}`)
|
await fetch(`https://dc-lookup.spiro.exhq.dev/v1/user/${id}`)
|
||||||
.then(res => res.json()).then(data => "https://proxy.spiro.exhq.dev/_/plain/"+data.avatar.link).catch(() => "https://http.cat/status/100"));
|
.then((res) => res.json())
|
||||||
|
.then((data) => "https://proxy.spiro.exhq.dev/_/plain/" + data.avatar.link)
|
||||||
|
.catch(() => "https://http.cat/status/100");
|
||||||
|
|
||||||
function SingleReview(props: NeoReview) {
|
function SingleReview(props: NeoReview) {
|
||||||
const [imageSrc, setImageSrc] = createSignal("");
|
const [imageSrc, setImageSrc] = createSignal("");
|
||||||
|
|
||||||
onMount(async () => {
|
onMount(async () => {
|
||||||
const url = await theImager(props.discordID);
|
const url = await theImager(props.discordID);
|
||||||
setImageSrc(url);
|
setImageSrc(url);
|
||||||
});
|
});
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div class="singlereview">
|
<div class="singlereview">
|
||||||
<img
|
<img
|
||||||
src={imageSrc()}
|
src={imageSrc()}
|
||||||
alt="User Avatar"
|
alt="User Avatar"
|
||||||
style={{"max-width": "3em", "border-radius": "30%"}}
|
style={{ "max-width": "3em", "border-radius": "30%" }}
|
||||||
/>
|
/>
|
||||||
<div class="reviewinfo">
|
<div class="reviewinfo">
|
||||||
<div class="reviewname">
|
<div class="reviewname">
|
||||||
{props.global_name === null ? props.username : props.global_name}
|
{props.global_name === null ? props.username : props.global_name}
|
||||||
</div>
|
|
||||||
<div class="reviewtext">{props.reviewText}</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
<div class="reviewtext">{props.reviewText}</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function sendReview(
|
||||||
|
review: string,
|
||||||
|
token: string,
|
||||||
|
): Promise<boolean> {
|
||||||
|
try {
|
||||||
|
const response = await fetch(
|
||||||
|
`https://review.exhq.dev/sendreview?review=${review}`,
|
||||||
|
{
|
||||||
|
headers: {
|
||||||
|
Auth: token,
|
||||||
|
},
|
||||||
|
method: "POST",
|
||||||
|
},
|
||||||
);
|
);
|
||||||
}
|
|
||||||
|
|
||||||
export async function sendReview(review: string, token: string): Promise<boolean> {
|
if (response.status !== 200) {
|
||||||
try {
|
return false;
|
||||||
const response = await fetch(`https://review.exhq.dev/sendreview?review=${review}`, {
|
|
||||||
headers: {
|
|
||||||
"Auth": token,
|
|
||||||
},
|
|
||||||
method: "POST"
|
|
||||||
});
|
|
||||||
|
|
||||||
if (response.status !== 200) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
} catch (error) {
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
} catch (error) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue