/* global swal, axios, ClipboardJS, LazyLoad */ var page = { // #page dom: null, // user token token: localStorage.token, username: null, // from api/tokens/verify // view config (either list or thumbs) filesView: localStorage.filesView, // current view (which album and which page) currentView: { album: null, pageNum: null }, // id of selected files (shared across pages and will be synced with localStorage) selectedFiles: [], checkboxes: [], lastSelected: null, // select album dom for dialogs/modals selectAlbumContainer: null, // cache of files and albums data for dialogs/modals files: {}, albums: {}, clipboardJS: null, lazyLoad: null, // byte units for getPrettyBytes() byteUnits: ['B', 'kB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'] } page.preparePage = function () { if (!page.token) { window.location = 'auth' return } page.verifyToken(page.token, true) } page.verifyToken = function (token, reloadOnError) { axios.post('api/tokens/verify', { token: token }) .then(function (response) { if (response.data.success === false) { return swal({ title: 'An error occurred!', text: response.data.description, icon: 'error' }) .then(function () { if (!reloadOnError) { return } localStorage.removeItem('token') location.location = 'auth' }) } axios.defaults.headers.common.token = token localStorage.token = token page.token = token page.username = response.data.username page.prepareDashboard() }) .catch(function (error) { console.log(error) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) } page.prepareDashboard = function () { page.dom = document.getElementById('page') page.dom.addEventListener('click', page.domClick, true) document.getElementById('auth').style.display = 'none' document.getElementById('dashboard').style.display = 'block' document.getElementById('itemUploads').addEventListener('click', function () { page.setActiveMenu(this) page.getUploads() }) document.getElementById('itemDeleteByNames').addEventListener('click', function () { page.setActiveMenu(this) page.deleteByNames() }) document.getElementById('itemManageGallery').addEventListener('click', function () { page.setActiveMenu(this) page.getAlbums() }) document.getElementById('itemFileLength').addEventListener('click', function () { page.setActiveMenu(this) page.changeFileLength() }) document.getElementById('itemTokens').addEventListener('click', function () { page.setActiveMenu(this) page.changeToken() }) document.getElementById('itemPassword').addEventListener('click', function () { page.setActiveMenu(this) page.changePassword() }) var logoutBtn = document.getElementById('itemLogout') logoutBtn.addEventListener('click', function () { page.logout() }) logoutBtn.innerHTML = 'Logout ( ' + page.username + ' )' page.getAlbumsSidebar() page.prepareShareX() } page.logout = function () { localStorage.removeItem('token') location.reload('.') } page.getItemID = function (element) { // This expects the item's parent to have the item's ID var parent = element.parentNode // If the element is part of a set of controls, use the container's parent instead if (element.parentNode.classList.contains('controls')) { parent = parent.parentNode } return parseInt(parent.dataset.id) } page.domClick = function (event) { var element = event.target if (!element) { return } // If the clicked element is an icon, delegate event to its A parent; hacky if (element.tagName === 'I' && element.parentNode.tagName === 'SPAN') { element = element.parentNode } if (element.tagName === 'SPAN' && element.parentNode.tagName === 'A') { element = element.parentNode } // Skip elements that have no action data if (!element.dataset || !element.dataset.action) { return } event.stopPropagation() // maybe necessary var id = page.getItemID(element) var action = element.dataset.action switch (action) { case 'page-prev': if (page.currentView.pageNum === 0) { return swal('Can\'t do that!', 'This is already the first page!', 'warning') } return page.getUploads(page.currentView.album, page.currentView.pageNum - 1, element) case 'page-next': return page.getUploads(page.currentView.album, page.currentView.pageNum + 1, element) case 'view-list': return page.setFilesView('list', element) case 'view-thumbs': return page.setFilesView('thumbs', element) case 'clear-selection': return page.clearSelection() case 'add-selected-files-to-album': return page.addSelectedFilesToAlbum() case 'bulk-delete': return page.deleteSelectedFiles() case 'select-file': return page.selectFile(element, event) case 'add-to-album': return page.addSingleFileToAlbum(id) case 'delete-file': return page.deleteFile(id) case 'select-all-files': return page.selectAllFiles(element) case 'display-thumbnail': return page.displayThumbnail(id) case 'delete-file-by-names': return page.deleteFileByNames() case 'submit-album': return page.submitAlbum(element) case 'edit-album': return page.editAlbum(id) case 'delete-album': return page.deleteAlbum(id) case 'get-new-token': return page.getNewToken(element) } } page.isLoading = function (element, state) { if (!element) { return } if (state) { return element.classList.add('is-loading') } element.classList.remove('is-loading') } page.getUploads = function (album, pageNum, element) { if (element) { page.isLoading(element, true) } if (pageNum === undefined) { pageNum = 0 } var url = 'api/uploads/' + pageNum if (album !== undefined) { url = 'api/album/' + album + '/' + pageNum } axios.get(url) .then(function (response) { if (response.data.success === false) { if (response.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', response.data.description, 'error') } } if (pageNum && (response.data.files.length === 0)) { // Only remove loading class here, since beyond this the entire page will be replaced anyways if (element) { page.isLoading(element, false) } return swal('Can\'t do that!', 'There are no more files!', 'warning') } page.files = {} var pagination = '' var controls = '
\n' + '
\n' + '
\n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + '
\n' + '
\n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' Bulk delete\n' + ' \n' + '
\n' + '
' var allFilesSelected = true var table, i, file, selected, displayAlbumOrUser if (page.filesView === 'thumbs') { page.dom.innerHTML = pagination + '\n' + '
\n' + controls + '\n' + '
\n' + '
\n' + pagination table = document.getElementById('table') for (i = 0; i < response.data.files.length; i++) { file = response.data.files[i] selected = page.selectedFiles.includes(file.id) if (!selected && allFilesSelected) { allFilesSelected = false } // Prettify file.prettyBytes = page.getPrettyBytes(parseInt(file.size)) file.prettyDate = page.getPrettyDate(new Date(file.timestamp * 1000)) displayAlbumOrUser = file.album if (page.username === 'root') { displayAlbumOrUser = '' if (file.username !== undefined) { displayAlbumOrUser = file.username } } var div = document.createElement('div') div.className = 'image-container column is-narrow' div.dataset.id = file.id if (file.thumb !== undefined) { div.innerHTML = '' + file.name + '' } else { div.innerHTML = '

' + (file.extname || 'N/A') + '

' } div.innerHTML += '\n' + '
\n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + '
\n' + '
\n' + '

' + file.name + '

\n' + '

' + (displayAlbumOrUser ? ('' + displayAlbumOrUser + ' – ') : '') + file.prettyBytes + '

\n' + '
' table.appendChild(div) page.checkboxes = Array.from(table.getElementsByClassName('file-checkbox')) page.lazyLoad.update() } } else { var albumOrUser = 'Album' if (page.username === 'root') { albumOrUser = 'User' } page.dom.innerHTML = pagination + '\n' + '
\n' + controls + '\n' + '
\n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + '
File' + albumOrUser + 'SizeDate
\n' + '
\n' + '
\n' + pagination table = document.getElementById('table') for (i = 0; i < response.data.files.length; i++) { file = response.data.files[i] selected = page.selectedFiles.includes(file.id) if (!selected && allFilesSelected) { allFilesSelected = false } page.files[file.id] = { name: file.name, thumb: file.thumb } // Prettify file.prettyBytes = page.getPrettyBytes(parseInt(file.size)) file.prettyDate = page.getPrettyDate(new Date(file.timestamp * 1000)) displayAlbumOrUser = file.album if (page.username === 'root') { displayAlbumOrUser = '' if (file.username !== undefined) { displayAlbumOrUser = file.username } } var tr = document.createElement('tr') tr.dataset.id = file.id tr.innerHTML = '\n' + '' + file.name + '\n' + '' + displayAlbumOrUser + '\n' + '' + file.prettyBytes + '\n' + '' + file.prettyDate + '\n' + '\n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + '' table.appendChild(tr) page.checkboxes = Array.from(table.getElementsByClassName('file-checkbox')) } } if (allFilesSelected && response.data.files.length) { var selectAll = document.getElementById('selectAll') if (selectAll) { selectAll.checked = true } } page.currentView.album = album page.currentView.pageNum = response.data.files.length ? pageNum : 0 }) .catch(function (error) { console.log(error) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) } page.setFilesView = function (view, element) { localStorage.filesView = view page.filesView = view page.getUploads(page.currentView.album, page.currentView.pageNum, element) } page.displayThumbnail = function (id) { var file = page.files[id] if (!file.thumb) { return } return swal({ text: file.name, content: { element: 'img', attributes: { src: file.thumb } }, button: true }) } page.selectAllFiles = function (element) { var table = document.getElementById('table') var checkboxes = table.getElementsByClassName('file-checkbox') for (var i = 0; i < checkboxes.length; i++) { var id = page.getItemID(checkboxes[i]) if (isNaN(id)) { continue } if (checkboxes[i].checked !== element.checked) { checkboxes[i].checked = element.checked if (checkboxes[i].checked) { page.selectedFiles.push(id) } else { page.selectedFiles.splice(page.selectedFiles.indexOf(id), 1) } } } if (page.selectedFiles.length) { localStorage.selectedFiles = JSON.stringify(page.selectedFiles) } else { localStorage.removeItem('selectedFiles') } element.title = element.checked ? 'Unselect all files' : 'Select all files' } page.selectInBetween = function (element, lastElement) { if (!element || !lastElement) { return } if (element === lastElement) { return } if (!page.checkboxes || !page.checkboxes.length) { return } var thisIndex = page.checkboxes.indexOf(element) var lastIndex = page.checkboxes.indexOf(lastElement) var distance = thisIndex - lastIndex if (distance >= -1 && distance <= 1) { return } for (var i = 0; i < page.checkboxes.length; i++) { if ((thisIndex > lastIndex && i > lastIndex && i < thisIndex) || (thisIndex < lastIndex && i > thisIndex && i < lastIndex)) { page.checkboxes[i].checked = true page.selectedFiles.push(page.getItemID(page.checkboxes[i])) } } localStorage.selectedFiles = JSON.stringify(page.selectedFiles) } page.selectFile = function (element, event) { if (event.shiftKey && page.lastSelected) { page.selectInBetween(element, page.lastSelected) } else { page.lastSelected = element } var id = page.getItemID(element) if (isNaN(id)) { return } if (!page.selectedFiles.includes(id) && element.checked) { page.selectedFiles.push(id) } else if (page.selectedFiles.includes(id) && !element.checked) { page.selectedFiles.splice(page.selectedFiles.indexOf(id), 1) } if (page.selectedFiles.length) { localStorage.selectedFiles = JSON.stringify(page.selectedFiles) } else { localStorage.removeItem('selectedFiles') } } page.clearSelection = function () { var count = page.selectedFiles.length if (!count) { return swal('An error occurred!', 'You have not selected any files.', 'error') } var suffix = 'file' + (count === 1 ? '' : 's') return swal({ title: 'Are you sure?', text: 'You are going to unselect ' + count + ' ' + suffix + '.', buttons: true }) .then(function (proceed) { if (!proceed) { return } var table = document.getElementById('table') var checkboxes = table.getElementsByClassName('file-checkbox') for (var i = 0; i < checkboxes.length; i++) { if (checkboxes[i].checked) { checkboxes[i].checked = false } } page.selectedFiles = [] localStorage.removeItem('selectedFiles') var selectAll = document.getElementById('selectAll') if (selectAll) { selectAll.checked = false } return swal('Cleared selection!', 'Unselected ' + count + ' ' + suffix + '.', 'success') }) } page.deleteFile = function (id) { // TODO: Share function with bulk delete, just like 'add selected files to album' and 'add single file to album' swal({ title: 'Are you sure?', text: 'You won\'t be able to recover the file!', icon: 'warning', dangerMode: true, buttons: { cancel: true, confirm: { text: 'Yes, delete it!', closeModal: false } } }) .then(function (proceed) { if (!proceed) { return } axios.post('api/upload/delete', { id: id }) .then(function (response) { if (!response) { return } if (response.data.success === false) { if (response.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', response.data.description, 'error') } } swal('Deleted!', 'The file has been deleted.', 'success') page.getUploads(page.currentView.album, page.currentView.pageNum) }) .catch(function (error) { console.log(error) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) }) } page.deleteSelectedFiles = function () { var count = page.selectedFiles.length if (!count) { return swal('An error occurred!', 'You have not selected any files.', 'error') } var suffix = 'file' + (count === 1 ? '' : 's') swal({ title: 'Are you sure?', text: 'You won\'t be able to recover ' + count + ' ' + suffix + '!', icon: 'warning', dangerMode: true, buttons: { cancel: true, confirm: { text: 'Yes, nuke the ' + suffix + '!', closeModal: false } } }) .then(function (proceed) { if (!proceed) { return } axios.post('api/upload/bulkdelete', { field: 'id', values: page.selectedFiles }) .then(function (bulkdelete) { if (!bulkdelete) { return } if (bulkdelete.data.success === false) { if (bulkdelete.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', bulkdelete.data.description, 'error') } } var deleted = count if (bulkdelete.data.failed && bulkdelete.data.failed.length) { deleted -= bulkdelete.data.failed.length page.selectedFiles = page.selectedFiles.filter(function (id) { return bulkdelete.data.failed.includes(id) }) } else { page.selectedFiles = [] } localStorage.selectedFiles = JSON.stringify(page.selectedFiles) swal('Deleted!', deleted + ' file' + (deleted === 1 ? ' has' : 's have') + ' been deleted.', 'success') return page.getUploads(page.currentView.album, page.currentView.pageNum) }) .catch(function (error) { console.log(error) swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) }) } page.deleteByNames = function () { page.dom.innerHTML = '

Delete by names

\n' + '
\n' + ' \n' + '
\n' + ' \n' + '
\n' + '

Separate each entry with a new line.

\n' + '
\n' + '
\n' + '
\n' + ' \n' + ' \n' + ' \n' + ' \n' + ' Bulk delete\n' + ' \n' + '
\n' + '
' } page.deleteFileByNames = function () { var names = document.getElementById('names').value .split(/\r?\n/) .filter(function (n) { return n.trim().length }) var count = names.length if (!count) { return swal('An error occurred!', 'You have not entered any file names.', 'error') } var suffix = 'file' + (count === 1 ? '' : 's') swal({ title: 'Are you sure?', text: 'You won\'t be able to recover ' + count + ' ' + suffix + '!', icon: 'warning', dangerMode: true, buttons: { cancel: true, confirm: { text: 'Yes, nuke the ' + suffix + '!', closeModal: false } } }) .then(function (proceed) { if (!proceed) { return } axios.post('api/upload/bulkdelete', { field: 'name', values: names }) .then(function (bulkdelete) { if (!bulkdelete) { return } if (bulkdelete.data.success === false) { if (bulkdelete.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', bulkdelete.data.description, 'error') } } var deleted = count if (bulkdelete.data.failed && bulkdelete.data.failed.length) { deleted -= bulkdelete.data.failed.length } document.getElementById('names').value = bulkdelete.data.failed.join('\n') swal('Deleted!', deleted + ' file' + (deleted === 1 ? ' has' : 's have') + ' been deleted.', 'success') }) .catch(function (error) { console.log(error) swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) }) } page.addSelectedFilesToAlbum = function () { var count = page.selectedFiles.length if (!count) { return swal('An error occurred!', 'You have not selected any files.', 'error') } page.addFilesToAlbum(page.selectedFiles, function (failed) { if (!failed) { return } if (failed.length) { page.selectedFiles = page.selectedFiles.filter(function (id) { return failed.includes(id) }) } else { page.selectedFiles = [] } localStorage.selectedFiles = JSON.stringify(page.selectedFiles) page.getUploads(page.currentView.album, page.currentView.pageNum) }) } page.addSingleFileToAlbum = function (id) { page.addFilesToAlbum([id], function (failed) { if (!failed) { return } page.getUploads(page.currentView.album, page.currentView.pageNum) }) } page.addFilesToAlbum = function (ids, callback) { var count = ids.length var content = document.createElement('div') content.id = 'addFilesToAlbum' content.innerHTML = '

You are about to add ' + count + ' file' + (count === 1 ? '' : 's') + ' to an album.

' + '
\n' + ' \n' + '
\n' + '
\n' + ' \n' + '
\n' + '
' swal({ title: 'Add to album', icon: 'warning', content: content, buttons: { cancel: true, confirm: { text: 'OK', closeModal: false } } }).then(function (choose) { if (!choose) { return } var container = document.getElementById('addFilesToAlbum') var select = container.getElementsByTagName('select')[0] var albumid = parseInt(select.value) if (isNaN(albumid)) { return swal('An error occurred!', 'You did not choose an album.', 'error') } axios.post('api/albums/addfiles', { ids: ids, albumid: albumid }).then(function (add) { if (!add) { return } if (add.data.success === false) { if (add.data.description === 'No token provided') { page.verifyToken(page.token) } else { swal('An error occurred!', add.data.description, 'error') } return } var added = ids.length if (add.data.failed && add.data.failed.length) { added -= add.data.failed.length } var suffix = 'file' + (ids.length === 1 ? '' : 's') if (!added) { return swal('An error occurred!', 'Could not add the ' + suffix + ' to the album.', 'error') } swal('Woohoo!', 'Successfully ' + (albumid < 0 ? 'removed' : 'added') + ' ' + added + ' ' + suffix + ' ' + (albumid < 0 ? 'from' : 'to') + ' the album.', 'success') return callback(add.data.failed) }).catch(function (error) { console.log(error) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) }).catch(function (error) { console.log(error) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) // Get albums list then update content of swal axios.get('api/albums').then(function (list) { if (list.data.success === false) { if (list.data.description === 'No token provided') { page.verifyToken(page.token) } else { swal('An error occurred!', list.data.description, 'error') } return } // If the prompt was replaced, the container would be missing var container = document.getElementById('addFilesToAlbum') if (!container) { return } var select = container.getElementsByTagName('select')[0] select.innerHTML += list.data.albums .map(function (album) { return '' }) .join('\n') select.getElementsByTagName('option')[1].innerHTML = 'Choose an album' select.removeAttribute('disabled') }).catch(function (error) { console.log(error) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) } page.getAlbums = function () { axios.get('api/albums') .then(function (response) { if (!response) { return } if (response.data.success === false) { if (response.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', response.data.description, 'error') } } page.albums = {} page.dom.innerHTML = '

Create new album

\n' + '
\n' + '
\n' + ' \n' + '
\n' + '
\n' + '
\n' + ' \n' + '
\n' + '
\n' + '

List of albums

\n' + '
\n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + '
IDNameFilesCreated atPublic link
\n' + '
' var homeDomain = response.data.homeDomain var table = document.getElementById('table') for (var i = 0; i < response.data.albums.length; i++) { var album = response.data.albums[i] var albumUrl = homeDomain + '/a/' + album.identifier // Prettify album.prettyDate = page.getPrettyDate(new Date(album.timestamp * 1000)) page.albums[album.id] = { name: album.name, download: album.download, public: album.public } var tr = document.createElement('tr') tr.innerHTML = '\n' + ' ' + album.id + '\n' + ' ' + album.name + '\n' + ' ' + album.files + '\n' + ' ' + album.prettyDate + '\n' + ' ' + albumUrl + '\n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + ' \n' + '' table.appendChild(tr) } }) .catch(function (error) { console.log(error) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) } page.editAlbum = function (id) { var album = page.albums[id] if (!album) { return } var div = document.createElement('div') div.innerHTML = '
\n' + ' \n' + '
\n' + ' \n' + '
\n' + '
\n' + '
\n' + '
\n' + ' \n' + '
\n' + '
\n' + '
\n' + '
\n' + ' \n' + '
\n' + '
\n' + '
\n' + '
\n' + ' \n' + '
\n' + '
' swal({ title: 'Edit album', icon: 'info', content: div, buttons: { cancel: true, confirm: { closeModal: false } } }) .then(function (value) { if (!value) { return } axios.post('api/albums/edit', { id: id, name: document.getElementById('_name').value, download: document.getElementById('_download').checked, public: document.getElementById('_public').checked, requestLink: document.getElementById('_requestLink').checked }) .then(function (response) { if (!response) { return } if (response.data.success === false) { if (response.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', response.data.description, 'error') } } if (response.data.identifier) { swal('Success!', 'Your album\'s new identifier is: ' + response.data.identifier + '.', 'success') } else if (response.data.name !== album.name) { swal('Success!', 'Your album was renamed to: ' + response.data.name + '.', 'success') } else { swal('Success!', 'Your album was edited!', 'success') } page.getAlbumsSidebar() page.getAlbums() }) .catch(function (error) { console.log(error) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) }) } page.deleteAlbum = function (id) { swal({ title: 'Are you sure?', text: 'This won\'t delete your files, only the album!', icon: 'warning', dangerMode: true, buttons: { cancel: true, confirm: { text: 'Yes, delete it!', closeModal: false }, purge: { text: 'Umm, delete the files too please?', value: 'purge', className: 'swal-button--danger', closeModal: false } } }) .then(function (proceed) { if (!proceed) { return } axios.post('api/albums/delete', { id: id, purge: proceed === 'purge' }) .then(function (response) { if (response.data.success === false) { if (response.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', response.data.description, 'error') } } swal('Deleted!', 'Your album has been deleted.', 'success') page.getAlbumsSidebar() page.getAlbums() }) .catch(function (error) { console.log(error) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) }) } page.submitAlbum = function (element) { page.isLoading(element, true) axios.post('api/albums', { name: document.getElementById('albumName').value }) .then(function (response) { if (!response) { return } page.isLoading(element, false) if (response.data.success === false) { if (response.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', response.data.description, 'error') } } swal('Woohoo!', 'Album was created successfully', 'success') page.getAlbumsSidebar() page.getAlbums() }) .catch(function (error) { console.log(error) page.isLoading(element, false) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) } page.getAlbumsSidebar = function () { axios.get('api/albums/sidebar') .then(function (response) { if (!response) { return } if (response.data.success === false) { if (response.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', response.data.description, 'error') } } var albumsContainer = document.getElementById('albumsContainer') albumsContainer.innerHTML = '' if (response.data.albums === undefined) { return } for (var i = 0; i < response.data.albums.length; i++) { var album = response.data.albums[i] var li = document.createElement('li') var a = document.createElement('a') a.id = album.id a.innerHTML = album.name a.addEventListener('click', function () { page.getAlbum(this) }) li.appendChild(a) albumsContainer.appendChild(li) } }) .catch(function (error) { console.log(error) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) } page.getAlbum = function (album) { page.setActiveMenu(album) page.getUploads(album.id) } page.changeFileLength = function () { axios.get('api/filelength/config') .then(function (response) { if (response.data.success === false) { if (response.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', response.data.description, 'error') } } page.dom.innerHTML = '

File name length

\n' + '
\n' + '
\n' + ' \n' + '
\n' + ' \n' + '
\n' + '

Default file name length is ' + response.data.config.default + ' characters. ' + (response.data.config.userChangeable ? ('Range allowed for user is ' + response.data.config.min + ' to ' + response.data.config.max + ' characters.') : 'Changing file name length is disabled at the moment.') + '

\n' + '
\n' + '
\n' + ' \n' + '
\n' + '
' document.getElementById('setFileLength').addEventListener('click', function () { page.setFileLength(document.getElementById('fileLength').value, this) }) }) .catch(function (error) { console.log(error) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) } page.setFileLength = function (fileLength, element) { page.isLoading(element, true) axios.post('api/filelength/change', { fileLength: fileLength }) .then(function (response) { page.isLoading(element, false) if (response.data.success === false) { if (response.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', response.data.description, 'error') } } swal({ title: 'Woohoo!', text: 'Your file length was successfully changed.', icon: 'success' }) .then(function () { page.changeFileLength() }) }) .catch(function (error) { console.log(error) page.isLoading(element, false) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) } page.changeToken = function () { axios.get('api/tokens') .then(function (response) { if (response.data.success === false) { if (response.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', response.data.description, 'error') } } page.dom.innerHTML = '

Manage your token

\n' + '
\n' + ' \n' + '
\n' + '
\n' + ' \n' + '
\n' + '
\n' + '
\n' + '' }) .catch(function (error) { console.log(error) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) } page.getNewToken = function (element) { page.isLoading(element, true) axios.post('api/tokens/change') .then(function (response) { page.isLoading(element, false) if (response.data.success === false) { if (response.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', response.data.description, 'error') } } swal({ title: 'Woohoo!', text: 'Your token was successfully changed.', icon: 'success' }) .then(function () { axios.defaults.headers.common.token = response.data.token localStorage.token = response.data.token page.token = response.data.token page.changeToken() }) }) .catch(function (error) { console.log(error) page.isLoading(element, false) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) } page.changePassword = function () { page.dom.innerHTML = '

Change your password

\n' + '
\n' + ' \n' + '
\n' + ' \n' + '
\n' + '
\n' + '
\n' + ' \n' + '
\n' + ' \n' + '
\n' + '
\n' + '' document.getElementById('sendChangePassword').addEventListener('click', function () { if (document.getElementById('password').value === document.getElementById('passwordConfirm').value) { page.sendNewPassword(document.getElementById('password').value, this) } else { swal({ title: 'Password mismatch!', text: 'Your passwords do not match, please try again.', icon: 'error' }) } }) } page.sendNewPassword = function (pass, element) { page.isLoading(element, true) axios.post('api/password/change', { password: pass }) .then(function (response) { page.isLoading(element, false) if (response.data.success === false) { if (response.data.description === 'No token provided') { return page.verifyToken(page.token) } else { return swal('An error occurred!', response.data.description, 'error') } } swal({ title: 'Woohoo!', text: 'Your password was successfully changed.', icon: 'success' }) .then(function () { page.changePassword() }) }) .catch(function (error) { console.log(error) page.isLoading(element, false) return swal('An error occurred!', 'There was an error with the request, please check the console for more information.', 'error') }) } page.setActiveMenu = function (activeItem) { var menu = document.getElementById('menu') var items = menu.getElementsByTagName('a') for (var i = 0; i < items.length; i++) { items[i].classList.remove('is-active') } activeItem.classList.add('is-active') } page.prepareShareX = function () { if (page.token) { // TODO: "location.origin" is unsuitable if the safe is hosted in a subdir (e.i. http://example.com/safe) var sharexElement = document.getElementById('ShareX') var sharexFile = '{\r\n' + ' "Name": "' + location.hostname + '",\r\n' + ' "DestinationType": "ImageUploader, FileUploader",\r\n' + ' "RequestType": "POST",\r\n' + ' "RequestURL": "' + location.origin + '/api/upload",\r\n' + ' "FileFormName": "files[]",\r\n' + ' "Headers": {\r\n' + ' "token": "' + page.token + '"\r\n' + ' },\r\n' + ' "ResponseType": "Text",\r\n' + ' "URL": "$json:files[0].url$",\r\n' + ' "ThumbnailURL": "$json:files[0].url$"\r\n' + '}' var sharexBlob = new Blob([sharexFile], { type: 'application/octet-binary' }) sharexElement.setAttribute('href', URL.createObjectURL(sharexBlob)) sharexElement.setAttribute('download', location.hostname + '.sxcu') } } page.getPrettyDate = date => { return date.getFullYear() + '-' + (date.getMonth() < 9 ? '0' : '') + // month's index starts from zero (date.getMonth() + 1) + '-' + (date.getDate() < 10 ? '0' : '') + date.getDate() + ' ' + (date.getHours() < 10 ? '0' : '') + date.getHours() + ':' + (date.getMinutes() < 10 ? '0' : '') + date.getMinutes() + ':' + (date.getSeconds() < 10 ? '0' : '') + date.getSeconds() } page.getPrettyBytes = num => { // MIT License // Copyright (c) Sindre Sorhus (sindresorhus.com) if (!Number.isFinite(num)) { return num } const neg = num < 0 if (neg) { num = -num } if (num < 1) { return (neg ? '-' : '') + num + ' B' } const exponent = Math.min(Math.floor(Math.log10(num) / 3), page.byteUnits.length - 1) const numStr = Number((num / Math.pow(1000, exponent)).toPrecision(3)) const unit = page.byteUnits[exponent] return (neg ? '-' : '') + numStr + ' ' + unit } window.onload = function () { // Add 'no-touch' class to non-touch devices if (!('ontouchstart' in document.documentElement)) { document.documentElement.classList.add('no-touch') } var selectedFiles = localStorage.selectedFiles if (selectedFiles) { page.selectedFiles = JSON.parse(selectedFiles) } page.preparePage() page.clipboardJS = new ClipboardJS('.clipboard-js') page.clipboardJS.on('success', function () { return swal('Copied!', 'The link has been copied to clipboard.', 'success') }) page.clipboardJS.on('error', function (event) { console.error(event) return swal('An error occurred!', 'There was an error when trying to copy the link to clipboard, please check the console for more information.', 'error') }) page.lazyLoad = new LazyLoad() }