Source: demavu.footer [edit]
<!-- content-wrapper ends --> <!-- partial:partials/_footer.html --> <footer class="footer"> <div class="d-sm-flex justify-content-center justify-content-sm-between"> <span class="text-muted d-block text-center text-sm-right d-sm-inline-block">Copyright (c) 2024, 52 Productions, Inc.</span> </div> </footer> <!-- partial --> </div> <!-- main-panel ends --> </div> <!-- page-body-wrapper ends --> </div> <!-- container-scroller --> <!-- plugins:js --> <script src="/assets/vendors/js/vendor.bundle.base.js"></script> <!-- endinject --> <!-- Plugin js for this page --> <script src="/assets/vendors/chart.js/Chart.min.js"></script> <script src="/assets/vendors/progressbar.js/progressbar.min.js"></script> <script src="/assets/vendors/jvectormap/jquery-jvectormap.min.js"></script> <script src="/assets/vendors/jvectormap/jquery-jvectormap-world-mill-en.js"></script> <script src="/assets/vendors/owl-carousel-2/owl.carousel.min.js"></script> <!-- End plugin js for this page --> <!-- inject:js --> <script src="/assets/js/off-canvas.js"></script> <script src="/assets/js/hoverable-collapse.js"></script> <script src="/assets/js/misc.js"></script> <script src="/assets/js/settings.js"></script> <script src="/assets/js/todolist.js"></script> <!-- endinject --> <!-- Custom js for this page --> <script src="/assets/js/dashboard.js"></script> <script> // Wrap the code inside the window.onload function window.onload = function() { // For each field of class editable, when it changes, enable the saveButton const editableFields = document.querySelectorAll('.editable'); editableFields.forEach(field => { // Get the source input and target field elements const sourceInput = document.getElementById(field.id); const saveBtn = document.getElementById("saveChangesButton"); // Listen for changes in the source input sourceInput.addEventListener('input', function() { saveBtn.disabled = false; }); }); // For each field of class "imgtext", changing it will update the src of an image with the same id, but txtIDNAME --> imgIDNAME const imageTexts = document.querySelectorAll('.imgtext'); imageTexts.forEach(field => { // Get the source input and target field elements const sourceInput = document.getElementById(field.id); const targetField = document.getElementById(field.id.replace("txt","img")); // Listen for changes in the source input sourceInput.addEventListener('input', function() { // Update the attribute of the target field based on the input's value const newValue = sourceInput.value; targetField.setAttribute('src', newValue); }); }); }; function addHtmlBefore(id, html) { // Get the button element by its ID var addBeforeElement = document.getElementById(id); // Insert the new HTML content before the button addBeforeElement.insertAdjacentHTML('beforebegin', html); const saveBtn = document.getElementById("saveChangesButton"); saveBtn.disabled = false; } // Function to call the web service // Data returned as a json object async function callWebService(url) { try { // Make the network request const response = await fetch(url); // Check if the request was successful if (!response.ok) { throw new Error(`HTTP error! status: ${response.status}`); } // Get the response const data = await response.text(); // Return the data return data; } catch (error) { console.error('Error fetching data: ', error); } } function addObject(category) { var name = prompt("New " + category.slice(0, -1) + "'s name:", ""); // Check if the user clicked "OK" and entered something if (name !== null) { var server = "staging"; const url = '/site/addRecord(' + server + "," + category + ',' + btoa(removeNonAsciiCharacters(name)) + ')'; callWebService(url) .then(data => { // Handle the data from the web service console.log('Received data:', data); location.reload(); }) .catch(error => { // Handle errors console.error('Error calling web service:', error); }); } } function removeObject(category, name) { if (confirm("Delete " + name + ": Do you want to proceed?")) { if (name !== null) { var server = "staging"; const url = '/site/removeRecord(' + server + "," + category + ',' + btoa(removeNonAsciiCharacters(name)) + ')'; callWebService(url) .then(data => { // Handle the data from the web service console.log('Received data:', data); location.replace("/site/games:current"); }) .catch(error => { // Handle errors console.error('Error calling web service:', error); }); } } else { console.log("User clicked Cancel"); } } function removeNonAsciiCharacters(inputString) { // Replace non-ASCII characters with an empty string const asciiString = inputString.replace(/[^\x00-\x7F]/g, ''); return asciiString; } function pushToProduction() { if (confirm("Are you sure? This may take a minute or two...")) { const url = '/site/copyDB:staging,production'; callWebService(url) .then(data => { // Handle the data from the web service console.log('Received data:', data); alert("Staging has been pushed to production."); }) .catch(error => { // Handle errors console.error('Error calling web service:', error); }); } } function saveEditableFields() { const editableFields = document.querySelectorAll('.editable'); // Iterate over each field editableFields.forEach(field => { // Get the ID of the field const fieldId = field.id; const metaData = field.title; // Get the content of the field const fieldValue = field.value; const server = "staging"; const url = '/site/updateRecord(' + server + "," + btoa(removeNonAsciiCharacters(metaData)) + "," + btoa(removeNonAsciiCharacters(fieldValue)) + ')'; const debugMsg = '/site/updateRecord(' + server + "," + removeNonAsciiCharacters(metaData) + "," + removeNonAsciiCharacters(fieldValue) + ')'; // alert(debugMsg); callWebService(url) .then(data => { // Handle the data from the web service console.log('path: ', metaData); console.log('Value: ', fieldValue); // console.log('Received data:', data); const saveBtn = document.getElementById("saveChangesButton"); saveBtn.disabled = true; //location.reload(); }) .catch(error => { // Handle errors console.error('Error calling web service:', error); }); }); } </script> <!-- End custom js for this page --> </body> </html>