mirror of
https://github.com/GCMatters/hermes.git
synced 2026-02-04 13:40:13 +01:00
feat: front-end overhaul. added search, editing, event view, validation
This commit is contained in:
97
WebApp/wwwroot/js/eventView.js
Normal file
97
WebApp/wwwroot/js/eventView.js
Normal file
@@ -0,0 +1,97 @@
|
||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||
return new (P || (P = Promise))(function (resolve, reject) {
|
||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||
});
|
||||
};
|
||||
import { getEvent, getMyAccount, unhideElementById } from './generalUseHelpers.js';
|
||||
const queryString = window.location.search;
|
||||
const urlParams = new URLSearchParams(queryString);
|
||||
const eventId = urlParams.get('event');
|
||||
document.addEventListener("DOMContentLoaded", () => __awaiter(void 0, void 0, void 0, function* () {
|
||||
var container = document.getElementById("mainContainer");
|
||||
var user = yield getMyAccount();
|
||||
var org_id = -1;
|
||||
const modifyBtn = document.getElementById("editBtn");
|
||||
const removeBtn = document.getElementById("removeBtn");
|
||||
if (user) {
|
||||
if (user.isOrganisation) {
|
||||
org_id = user.organisationId;
|
||||
}
|
||||
unhideElementById(document, "logout-btn");
|
||||
}
|
||||
else {
|
||||
unhideElementById(document, "joinnow-btn");
|
||||
unhideElementById(document, "signin-btn");
|
||||
}
|
||||
var thisEvent = null;
|
||||
try {
|
||||
if (eventId)
|
||||
thisEvent = yield getEvent(eventId);
|
||||
}
|
||||
catch (err) {
|
||||
if (container !== null)
|
||||
container.innerHTML = `<p class="text-danger">To wydarzenie nie istnieje! <a href="/" style="color:#2898BD;">Powrót -></a></p>`;
|
||||
}
|
||||
if (thisEvent == null) {
|
||||
if (container !== null)
|
||||
container.innerHTML = `<p class="text-danger">Błąd we wczytywaniu wydarzenia. <a href="/" style="color:#2898BD;">Powrót -></a></p>`;
|
||||
}
|
||||
else {
|
||||
const titleText = document.getElementById("titleText");
|
||||
const locationText = document.getElementById("locationText");
|
||||
const descText = document.getElementById("descText");
|
||||
const dateText = document.getElementById("dateText");
|
||||
const organizerText = document.getElementById("organizerText");
|
||||
const newdateText = new Date(thisEvent.eventDate).toLocaleDateString('pl-PL');
|
||||
const newtimeText = new Date(thisEvent.eventDate).toLocaleTimeString('pl-PL');
|
||||
titleText.innerHTML = thisEvent.title + ` (#${eventId})`;
|
||||
locationText.innerHTML = "Place: " + thisEvent.location;
|
||||
descText.innerHTML = thisEvent.description;
|
||||
dateText.innerHTML = "When: " + newdateText + " " + newtimeText; //thisEvent.eventDate;
|
||||
organizerText.innerHTML = "Organized by: " + thisEvent.organisationName;
|
||||
if (org_id == thisEvent.organisationId) {
|
||||
// Użytkownik jest organizacją, która
|
||||
// stworzyła to wydarzenie
|
||||
unhideElementById(document, "editBtn");
|
||||
unhideElementById(document, "removeBtn");
|
||||
}
|
||||
else if (org_id == -1) {
|
||||
// Użytkownik jest wolontariuszem
|
||||
unhideElementById(document, "applyBtn");
|
||||
}
|
||||
unhideElementById(document, "mainContainer");
|
||||
}
|
||||
if (modifyBtn) {
|
||||
modifyBtn.addEventListener("click", (e) => {
|
||||
window.location.href = "/modify.html?event=" + eventId;
|
||||
});
|
||||
}
|
||||
if (removeBtn) {
|
||||
removeBtn.addEventListener("click", (e) => __awaiter(void 0, void 0, void 0, function* () {
|
||||
const confirmed = confirm("Really delete?");
|
||||
if (!confirmed)
|
||||
return;
|
||||
try {
|
||||
// Wysyła żądanie DELETE do API
|
||||
const response = yield fetch(`/api/events/${id}`, {
|
||||
method: "DELETE"
|
||||
});
|
||||
if (response.ok) {
|
||||
alert("Event deleted.");
|
||||
window.location.href = "/";
|
||||
}
|
||||
else {
|
||||
alert("Couldn't delete event.");
|
||||
}
|
||||
}
|
||||
catch (err) {
|
||||
alert("Couldn't connect.");
|
||||
console.error(err);
|
||||
}
|
||||
}));
|
||||
}
|
||||
}));
|
||||
Reference in New Issue
Block a user