+ Wurde der Betrag in die Kasse eingezahlt? +
+ +diff --git a/src/routes/api/v1/transaction/transaction.ts b/src/routes/api/v1/transaction/transaction.ts index 9622548..a4e0753 100644 --- a/src/routes/api/v1/transaction/transaction.ts +++ b/src/routes/api/v1/transaction/transaction.ts @@ -163,7 +163,8 @@ async function patch(req: Request, res: Response) { }, data: { userId: value.user_id, - paid: value.paid + paid: value.paid, + // !!!!! paidAt: value.paid ? new Date() : undefined }, select: { id: true diff --git a/src/routes/api/v1/transaction/transaction_schema.ts b/src/routes/api/v1/transaction/transaction_schema.ts index 6dad1cd..c87a036 100644 --- a/src/routes/api/v1/transaction/transaction_schema.ts +++ b/src/routes/api/v1/transaction/transaction_schema.ts @@ -30,6 +30,7 @@ const schema_post = validator.object({ // MARK: UPDATE transaction const schema_patch = validator.object({ + id: validator.number().positive().precision(0).required(), user_id: validator.number().positive().precision(0).required(), paid: validator.boolean().default(false) }); diff --git a/static/apiWrapper.js b/static/apiWrapper.js index 8ead0ca..421ea48 100644 --- a/static/apiWrapper.js +++ b/static/apiWrapper.js @@ -100,13 +100,13 @@ let _api = { // Handle the response if (!response.ok) { _testPageFail(response.statusText); - return; + return -1; } const result = await response.json(); // Handle the result, was json valid? if (!result) { _testPageFail('Invalid JSON response'); - return; + return -1; } return result; diff --git a/static/pageDriver.js b/static/pageDriver.js index e7845de..7b9bf76 100644 --- a/static/pageDriver.js +++ b/static/pageDriver.js @@ -240,6 +240,7 @@ modalForms.forEach((modalForm) => { console.log('Response: ', resp); if (resp['status'] == 'CREATED' || resp['status'] == 'UPDATED') { console.log('Entry created successfully'); + createTemporaryNotification('Eintrag erfolgreich aktualisiert', 'is-success'); modalForm.closest('.modal').classList.remove('is-active'); modalForm.reset(); // Hide loadPhase @@ -260,12 +261,18 @@ modalForms.forEach((modalForm) => { entryPhase.classList.remove('is-hidden'); } // TODO: Show error message + createTemporaryNotification('Error while creating entry', 'is-danger'); } // Find all tables with data-searchTargetId set to table setTimeout(() => { - refreshTableByName(table); - updateSingeltonsByTableName(table); + if(modalForm.getAttribute('data-extTable') != null) { + refreshTableByName(table); + updateSingeltonsByTableName(table); + } else { + refreshTableByName(document.getElementById(modalForm.getAttribute('data-extTable'))); + } + }, 500); }); }); @@ -680,4 +687,31 @@ document.addEventListener('DOMContentLoaded', () => { $notification.parentNode.removeChild($notification); }); }); - }); \ No newline at end of file + }); + +function getCookie(name) { + let value = "; " + document.cookie; + let parts = value.split("; " + name + "="); + if(parts.length == 2) { + return parts.pop().split(";").shift(); + } +} + +function eraseCookie(name) { + document.cookie = name + '=; Max-Age=-99999999;'; +} + +function errorIfAnyUndefined(inp) { + console.log(inp) + for(var i = 0; i < inp.length; i++) { + if(inp[i] == undefined) { + console.error("Missing element!") + createTemporaryNotification("Beim Laden der Seite ist ein Fehler aufgetreten", "is-danger", 90000) + } + } +} + +function formatTimestamp(timestamp) { + const date = new Date(timestamp); + return date.toLocaleString(); +} \ No newline at end of file diff --git a/static/pages/payup.js b/static/pages/payup.js index e112573..092df46 100644 --- a/static/pages/payup.js +++ b/static/pages/payup.js @@ -1,4 +1,77 @@ const tableContent = document.querySelector('.table-content'); -const tableSum = document.querySelector('.table-sum'); +// HTML Elements +const isEmptyAlert = document.getElementById("noBalance"); +const tableDiv = document.getElementById("balanceSheet"); +const payTable = document.getElementById("payTable"); +const tableCnt = document.getElementById("table-content"); +const tableSum = document.getElementById("table-sum"); +const modal_sum = document.getElementById("ModalSum"); +const confirmModal = document.getElementById("confirmModal"); +const btn_paynow = document.getElementById("paynow"); +const btn_confirm = document.getElementById("confirmCheckout"); +const btn_logout = document.getElementById("logout"); -alert("NYI: Endpoint is not yet implemented. This demo ends here."); \ No newline at end of file +errorIfAnyUndefined([isEmptyAlert, tableDiv, payTable, tableCnt, tableSum, modal_sum]) + +// Current user +let cookieUser = getCookie('user'); + +if(cookieUser == undefined) { + createTemporaryNotification('Fehler: Nutzer nicht angemeldet.', 'is-danger'); + window.location.href = '/user_select'; +} + +let transactionIds = []; + +// Request outstanding transactions by user +async function pullData() { + let data = await _api.get("transaction?user_id=" + parseInt(cookieUser) + "&paid=false"); + console.log(data) + if(data.count == 0) { + isEmptyAlert.classList.remove("is-hidden"); + tableDiv.classList.add("is-hidden"); + return; + } + // Write data to table + const result = data.result; + let priceSum = 0; + for(var i = 0; i < data.count; i++) { + const row = result[i]; + const newRow = tableCnt.insertRow(); + newRow.id = `row_${row.id}`; + newRow.innerHTML = ` +
Bez. | +Austellungsdatum | Preis | -- - |
---|---|---|---|
- |
Bezahlung bestätigen
+ ++ Wurde der Betrag in die Kasse eingezahlt? +
+ +