From 999c148dff3d27e4a4d5b59d6408a015c2922320 Mon Sep 17 00:00:00 2001 From: Pitu Date: Tue, 31 Jan 2017 03:37:17 -0300 Subject: Changed /panel to /dashboard --- lolisafe.js | 2 +- pages/dashboard.html | 70 ++++++ pages/home.html | 2 +- pages/panel.html | 70 ------ public/js/auth.js | 4 +- public/js/dashboard.js | 589 +++++++++++++++++++++++++++++++++++++++++++++++++ public/js/home.js | 5 +- public/js/panel.js | 589 ------------------------------------------------- 8 files changed, 667 insertions(+), 664 deletions(-) create mode 100644 pages/dashboard.html delete mode 100644 pages/panel.html create mode 100644 public/js/dashboard.js delete mode 100644 public/js/panel.js diff --git a/lolisafe.js b/lolisafe.js index 74258f2..f31b70e 100644 --- a/lolisafe.js +++ b/lolisafe.js @@ -24,7 +24,7 @@ safe.use('/api', api) safe.get('/', (req, res, next) => res.sendFile('home.html', { root: './pages/' })) safe.get('/faq', (req, res, next) => res.sendFile('faq.html', { root: './pages/' })) safe.get('/auth', (req, res, next) => res.sendFile('auth.html', { root: './pages/' })) -safe.get('/panel', (req, res, next) => res.sendFile('panel.html', { root: './pages/' })) +safe.get('/dashboard', (req, res, next) => res.sendFile('dashboard.html', { root: './pages/' })) safe.use((req, res, next) => res.status(404).sendFile('404.html', { root: './pages/error/' })) safe.use((req, res, next) => res.status(500).sendFile('500.html', { root: './pages/error/' })) diff --git a/pages/dashboard.html b/pages/dashboard.html new file mode 100644 index 0000000..3b5303d --- /dev/null +++ b/pages/dashboard.html @@ -0,0 +1,70 @@ + + + + lolisafe - A small safe worth protecting. + + + + + + + + + + +
+ +
+
+

+ Admin dashboard +

+

+

+ + Check +

+

+
+
+ +
+ +
+ +
+

Dashboard

+

A simple dashboard, to sort your uploaded stuff

+
+
+
+ +
+
+ +
+
+
+ +
+ + \ No newline at end of file diff --git a/pages/home.html b/pages/home.html index e620513..86cb2a4 100644 --- a/pages/home.html +++ b/pages/home.html @@ -44,7 +44,7 @@

diff --git a/pages/panel.html b/pages/panel.html deleted file mode 100644 index c8ae8cb..0000000 --- a/pages/panel.html +++ /dev/null @@ -1,70 +0,0 @@ - - - - lolisafe - A small safe worth protecting. - - - - - - - - - - -
- -
-
-

- Admin dashboard -

-

-

- - Check -

-

-
-
- -
- -
- -
-

Dashboard

-

A simple dashboard, to sort your uploaded stuff

-
-
-
- -
-
- -
-
-
- -
- - \ No newline at end of file diff --git a/public/js/auth.js b/public/js/auth.js index 68cf9e3..ecc7c7c 100644 --- a/public/js/auth.js +++ b/public/js/auth.js @@ -20,7 +20,7 @@ page.do = function(dest){ return swal('Error', response.data.description, 'error'); localStorage.token = response.data.token; - window.location = '/panel'; + window.location = '/dashboard'; }) .catch(function (error) { @@ -41,7 +41,7 @@ page.verify = function(){ if(response.data.success === false) return swal('Error', response.data.description, 'error'); - window.location = '/panel'; + window.location = '/dashboard'; }) .catch(function (error) { diff --git a/public/js/dashboard.js b/public/js/dashboard.js new file mode 100644 index 0000000..ac53f35 --- /dev/null +++ b/public/js/dashboard.js @@ -0,0 +1,589 @@ +let panel = {} + +panel.page; +panel.token = localStorage.token; +panel.filesView = localStorage.filesView; + +panel.preparePage = function(){ + if(!panel.token) return window.location = '/auth'; + panel.verifyToken(panel.token, true); +} + +panel.verifyToken = function(token, reloadOnError){ + if(reloadOnError === undefined) + reloadOnError = false; + + axios.post('/api/tokens/verify', { + token: token + }) + .then(function (response) { + + if(response.data.success === false){ + swal({ + title: "An error ocurred", + text: response.data.description, + type: "error" + }, function(){ + if(reloadOnError){ + localStorage.removeItem("token"); + location.location = '/auth'; + } + }) + return; + } + + axios.defaults.headers.common['token'] = token; + localStorage.token = token; + panel.token = token; + return panel.prepareDashboard(); + + }) + .catch(function (error) { + return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); + console.log(error); + }); + +} + +panel.prepareDashboard = function(){ + panel.page = document.getElementById('page'); + document.getElementById('auth').style.display = 'none'; + document.getElementById('dashboard').style.display = 'block'; + + document.getElementById('itemUploads').addEventListener('click', function(){ + panel.setActiveMenu(this); + }); + + document.getElementById('itemManageGallery').addEventListener('click', function(){ + panel.setActiveMenu(this); + }); + + document.getElementById('itemTokens').addEventListener('click', function(){ + panel.setActiveMenu(this); + }); + + panel.getAlbumsSidebar(); +} + +panel.logout = function(){ + localStorage.removeItem("token"); + location.reload('/'); +} + +panel.getUploads = function(album = undefined, page = undefined){ + + if(page === undefined) page = 0; + + let url = '/api/uploads/' + page + if(album !== undefined) + url = '/api/album/' + album + '/' + page + + axios.get(url).then(function (response) { + if(response.data.success === false){ + if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); + else return swal("An error ocurred", response.data.description, "error"); + } + + var prevPage = 0; + var nextPage = page + 1; + + if(response.data.files.length < 25) + nextPage = page; + + if(page > 0) prevPage = page - 1; + + panel.page.innerHTML = ''; + var container = document.createElement('div'); + var pagination = ``; + var listType = ` +
+ +
` + + if(panel.filesView === 'thumbs'){ + + container.innerHTML = ` + ${pagination} +
+ ${listType} +
+ +
+ ${pagination} + `; + + panel.page.appendChild(container); + var table = document.getElementById('table'); + + for(var item of response.data.files){ + + var div = document.createElement('div'); + div.className = "column is-2"; + if(item.thumb !== undefined) + div.innerHTML = ``; + else + div.innerHTML = `

.${item.file.split('.').pop()}

`; + table.appendChild(div); + + } + + }else{ + + container.innerHTML = ` + ${pagination} +
+ ${listType} + + + + + + + + + + + +
FileAlbumDate
+
+ ${pagination} + `; + + panel.page.appendChild(container); + var table = document.getElementById('table'); + + for(var item of response.data.files){ + + var tr = document.createElement('tr'); + tr.innerHTML = ` + + ${item.file} + ${item.album} + ${item.date} + + + + + + + + + `; + + table.appendChild(tr); + } + } + }) + .catch(function (error) { + return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); + console.log(error); + }); + +} + +panel.setFilesView = function(view, album, page){ + localStorage.filesView = view; + panel.filesView = view; + panel.getUploads(album, page); +} + +panel.deleteFile = function(id){ + swal({ + title: "Are you sure?", + text: "You wont be able to recover the file!", + type: "warning", + showCancelButton: true, + confirmButtonColor: "#ff3860", + confirmButtonText: "Yes, delete it!", + closeOnConfirm: false + }, + function(){ + + axios.post('/api/upload/delete', { + id: id + }) + .then(function (response) { + + if(response.data.success === false){ + if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); + else return swal("An error ocurred", response.data.description, "error"); + } + + swal("Deleted!", "The file has been deleted.", "success"); + panel.getUploads(); + return; + + }) + .catch(function (error) { + return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); + console.log(error); + }); + + } + ); +} + +panel.getAlbums = function(){ + + axios.get('/api/albums').then(function (response) { + if(response.data.success === false){ + if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); + else return swal("An error ocurred", response.data.description, "error"); + } + + panel.page.innerHTML = ''; + var container = document.createElement('div'); + container.className = "container"; + container.innerHTML = ` +

Create new album

+ +

+ + Submit +

+ +

List of albums

+ + + + + + + + + + + + +
NameFilesCreated At
`; + + panel.page.appendChild(container); + var table = document.getElementById('table'); + + for(var item of response.data.albums){ + + var tr = document.createElement('tr'); + tr.innerHTML = ` + + ${item.name} + ${item.files} + ${item.date} + + + + + + + + + + + + + + `; + + table.appendChild(tr); + } + + document.getElementById('submitAlbum').addEventListener('click', function(){ + panel.submitAlbum(); + }); + + }) + .catch(function (error) { + return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); + console.log(error); + }); + +} + +panel.renameAlbum = function(id){ + + swal({ + title: "Rename album", + text: "New name you want to give the album:", + type: "input", + showCancelButton: true, + closeOnConfirm: false, + animation: "slide-from-top", + inputPlaceholder: "My super album" + },function(inputValue){ + if (inputValue === false) return false; + if (inputValue === "") { + swal.showInputError("You need to write something!"); + return false + } + + axios.post('/api/albums/rename', { + id: id, + name: inputValue + }) + .then(function (response) { + + if(response.data.success === false){ + if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); + else if(response.data.description === 'Name already in use') swal.showInputError("That name is already in use!"); + else swal("An error ocurred", response.data.description, "error"); + return; + } + + swal("Success!", "Your album was renamed to: " + inputValue, "success"); + panel.getAlbumsSidebar(); + panel.getAlbums(); + return; + + }) + .catch(function (error) { + return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); + console.log(error); + }); + + }); + +} + +panel.deleteAlbum = function(id){ + swal({ + title: "Are you sure?", + text: "This won't delete your files, only the album!", + type: "warning", + showCancelButton: true, + confirmButtonColor: "#ff3860", + confirmButtonText: "Yes, delete it!", + closeOnConfirm: false + }, + function(){ + + axios.post('/api/albums/delete', { + id: id + }) + .then(function (response) { + + if(response.data.success === false){ + if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); + else return swal("An error ocurred", response.data.description, "error"); + } + + swal("Deleted!", "Your album has been deleted.", "success"); + panel.getAlbumsSidebar(); + panel.getAlbums(); + return; + + }) + .catch(function (error) { + return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); + console.log(error); + }); + + } + ); + +} + +panel.submitAlbum = function(){ + + axios.post('/api/albums', { + name: document.getElementById('albumName').value + }) + .then(function (response) { + + if(response.data.success === false){ + if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); + else return swal("An error ocurred", response.data.description, "error"); + } + + swal("Woohoo!", "Album was added successfully", "success"); + panel.getAlbumsSidebar(); + panel.getAlbums(); + return; + + }) + .catch(function (error) { + return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); + console.log(error); + }); + +} + +panel.getAlbumsSidebar = function(){ + + axios.get('/api/albums/sidebar') + .then(function (response) { + if(response.data.success === false){ + if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); + else return swal("An error ocurred", response.data.description, "error"); + } + + var albumsContainer = document.getElementById('albumsContainer'); + albumsContainer.innerHTML = ''; + + if(response.data.albums === undefined) return; + + for(var album of response.data.albums){ + + li = document.createElement('li'); + a = document.createElement('a'); + a.id = album.id; + a.innerHTML = album.name; + + a.addEventListener('click', function(){ + panel.getAlbum(this); + }); + + li.appendChild(a); + albumsContainer.appendChild(li); + } + + + }) + .catch(function (error) { + return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); + console.log(error); + }); + +} + +panel.getAlbum = function(item){ + panel.setActiveMenu(item); + panel.getUploads(item.id); +} + +panel.changeToken = function(){ + + axios.get('/api/tokens') + .then(function (response) { + if(response.data.success === false){ + if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); + else return swal("An error ocurred", response.data.description, "error"); + } + + panel.page.innerHTML = ''; + var container = document.createElement('div'); + container.className = "container"; + container.innerHTML = ` +

Manage your token

+ + +

+ + Request new token +

+ `; + + panel.page.appendChild(container); + + document.getElementById('getNewToken').addEventListener('click', function(){ + panel.getNewToken(); + }); + + }) + .catch(function (error) { + return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); + console.log(error); + }); + +} + +panel.getNewToken = function(){ + + axios.post('/api/tokens/change') + .then(function (response) { + + if(response.data.success === false){ + if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); + else return swal("An error ocurred", response.data.description, "error"); + } + + swal({ + title: "Woohoo!", + text: 'Your token was changed successfully.', + type: "success" + }, function(){ + localStorage.token = response.data.token; + location.reload(); + }) + + }) + .catch(function (error) { + return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); + console.log(error); + }); + +} + +panel.changePassword = function(){ + + panel.page.innerHTML = ''; + var container = document.createElement('div'); + container.className = "container"; + container.innerHTML = ` +

Change your password

+ + +

+ + Set new password +

+ `; + + panel.page.appendChild(container); + + document.getElementById('sendChangePassword').addEventListener('click', function(){ + panel.sendNewPassword(document.getElementById('password').value); + }); + +} + +panel.sendNewPassword = function(pass){ + + axios.post('/api/password/change', {password: pass}) + .then(function (response) { + + if(response.data.success === false){ + if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); + else return swal("An error ocurred", response.data.description, "error"); + } + + swal({ + title: "Woohoo!", + text: 'Your password was changed successfully.', + type: "success" + }, function(){ + location.reload(); + }) + + }) + .catch(function (error) { + return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); + console.log(error); + }); + +} + +panel.setActiveMenu = function(item){ + var menu = document.getElementById('menu'); + var items = menu.getElementsByTagName('a'); + for(var i = 0; i < items.length; i++) + items[i].className = ""; + + item.className = 'is-active'; +} + +window.onload = function () { + panel.preparePage(); +} diff --git a/public/js/home.js b/public/js/home.js index cd06cc2..6253c10 100644 --- a/public/js/home.js +++ b/public/js/home.js @@ -69,7 +69,10 @@ upload.prepareUpload = function(){ document.getElementById('maxFileSize').innerHTML = 'Maximum upload size per file is ' + upload.maxFileSize; document.getElementById('loginToUpload').style.display = 'none'; - document.getElementById('loginLinkText').innerHTML = 'Create an account and keep track of your uploads'; + + if(upload.token === undefined) + document.getElementById('loginLinkText').innerHTML = 'Create an account and keep track of your uploads'; + document.getElementById('uploadContainer').appendChild(div); upload.prepareDropzone(); diff --git a/public/js/panel.js b/public/js/panel.js deleted file mode 100644 index ac53f35..0000000 --- a/public/js/panel.js +++ /dev/null @@ -1,589 +0,0 @@ -let panel = {} - -panel.page; -panel.token = localStorage.token; -panel.filesView = localStorage.filesView; - -panel.preparePage = function(){ - if(!panel.token) return window.location = '/auth'; - panel.verifyToken(panel.token, true); -} - -panel.verifyToken = function(token, reloadOnError){ - if(reloadOnError === undefined) - reloadOnError = false; - - axios.post('/api/tokens/verify', { - token: token - }) - .then(function (response) { - - if(response.data.success === false){ - swal({ - title: "An error ocurred", - text: response.data.description, - type: "error" - }, function(){ - if(reloadOnError){ - localStorage.removeItem("token"); - location.location = '/auth'; - } - }) - return; - } - - axios.defaults.headers.common['token'] = token; - localStorage.token = token; - panel.token = token; - return panel.prepareDashboard(); - - }) - .catch(function (error) { - return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); - console.log(error); - }); - -} - -panel.prepareDashboard = function(){ - panel.page = document.getElementById('page'); - document.getElementById('auth').style.display = 'none'; - document.getElementById('dashboard').style.display = 'block'; - - document.getElementById('itemUploads').addEventListener('click', function(){ - panel.setActiveMenu(this); - }); - - document.getElementById('itemManageGallery').addEventListener('click', function(){ - panel.setActiveMenu(this); - }); - - document.getElementById('itemTokens').addEventListener('click', function(){ - panel.setActiveMenu(this); - }); - - panel.getAlbumsSidebar(); -} - -panel.logout = function(){ - localStorage.removeItem("token"); - location.reload('/'); -} - -panel.getUploads = function(album = undefined, page = undefined){ - - if(page === undefined) page = 0; - - let url = '/api/uploads/' + page - if(album !== undefined) - url = '/api/album/' + album + '/' + page - - axios.get(url).then(function (response) { - if(response.data.success === false){ - if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); - else return swal("An error ocurred", response.data.description, "error"); - } - - var prevPage = 0; - var nextPage = page + 1; - - if(response.data.files.length < 25) - nextPage = page; - - if(page > 0) prevPage = page - 1; - - panel.page.innerHTML = ''; - var container = document.createElement('div'); - var pagination = ``; - var listType = ` -
- -
` - - if(panel.filesView === 'thumbs'){ - - container.innerHTML = ` - ${pagination} -
- ${listType} -
- -
- ${pagination} - `; - - panel.page.appendChild(container); - var table = document.getElementById('table'); - - for(var item of response.data.files){ - - var div = document.createElement('div'); - div.className = "column is-2"; - if(item.thumb !== undefined) - div.innerHTML = ``; - else - div.innerHTML = `

.${item.file.split('.').pop()}

`; - table.appendChild(div); - - } - - }else{ - - container.innerHTML = ` - ${pagination} -
- ${listType} - - - - - - - - - - - -
FileAlbumDate
-
- ${pagination} - `; - - panel.page.appendChild(container); - var table = document.getElementById('table'); - - for(var item of response.data.files){ - - var tr = document.createElement('tr'); - tr.innerHTML = ` - - ${item.file} - ${item.album} - ${item.date} - - - - - - - - - `; - - table.appendChild(tr); - } - } - }) - .catch(function (error) { - return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); - console.log(error); - }); - -} - -panel.setFilesView = function(view, album, page){ - localStorage.filesView = view; - panel.filesView = view; - panel.getUploads(album, page); -} - -panel.deleteFile = function(id){ - swal({ - title: "Are you sure?", - text: "You wont be able to recover the file!", - type: "warning", - showCancelButton: true, - confirmButtonColor: "#ff3860", - confirmButtonText: "Yes, delete it!", - closeOnConfirm: false - }, - function(){ - - axios.post('/api/upload/delete', { - id: id - }) - .then(function (response) { - - if(response.data.success === false){ - if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); - else return swal("An error ocurred", response.data.description, "error"); - } - - swal("Deleted!", "The file has been deleted.", "success"); - panel.getUploads(); - return; - - }) - .catch(function (error) { - return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); - console.log(error); - }); - - } - ); -} - -panel.getAlbums = function(){ - - axios.get('/api/albums').then(function (response) { - if(response.data.success === false){ - if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); - else return swal("An error ocurred", response.data.description, "error"); - } - - panel.page.innerHTML = ''; - var container = document.createElement('div'); - container.className = "container"; - container.innerHTML = ` -

Create new album

- -

- - Submit -

- -

List of albums

- - - - - - - - - - - - -
NameFilesCreated At
`; - - panel.page.appendChild(container); - var table = document.getElementById('table'); - - for(var item of response.data.albums){ - - var tr = document.createElement('tr'); - tr.innerHTML = ` - - ${item.name} - ${item.files} - ${item.date} - - - - - - - - - - - - - - `; - - table.appendChild(tr); - } - - document.getElementById('submitAlbum').addEventListener('click', function(){ - panel.submitAlbum(); - }); - - }) - .catch(function (error) { - return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); - console.log(error); - }); - -} - -panel.renameAlbum = function(id){ - - swal({ - title: "Rename album", - text: "New name you want to give the album:", - type: "input", - showCancelButton: true, - closeOnConfirm: false, - animation: "slide-from-top", - inputPlaceholder: "My super album" - },function(inputValue){ - if (inputValue === false) return false; - if (inputValue === "") { - swal.showInputError("You need to write something!"); - return false - } - - axios.post('/api/albums/rename', { - id: id, - name: inputValue - }) - .then(function (response) { - - if(response.data.success === false){ - if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); - else if(response.data.description === 'Name already in use') swal.showInputError("That name is already in use!"); - else swal("An error ocurred", response.data.description, "error"); - return; - } - - swal("Success!", "Your album was renamed to: " + inputValue, "success"); - panel.getAlbumsSidebar(); - panel.getAlbums(); - return; - - }) - .catch(function (error) { - return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); - console.log(error); - }); - - }); - -} - -panel.deleteAlbum = function(id){ - swal({ - title: "Are you sure?", - text: "This won't delete your files, only the album!", - type: "warning", - showCancelButton: true, - confirmButtonColor: "#ff3860", - confirmButtonText: "Yes, delete it!", - closeOnConfirm: false - }, - function(){ - - axios.post('/api/albums/delete', { - id: id - }) - .then(function (response) { - - if(response.data.success === false){ - if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); - else return swal("An error ocurred", response.data.description, "error"); - } - - swal("Deleted!", "Your album has been deleted.", "success"); - panel.getAlbumsSidebar(); - panel.getAlbums(); - return; - - }) - .catch(function (error) { - return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); - console.log(error); - }); - - } - ); - -} - -panel.submitAlbum = function(){ - - axios.post('/api/albums', { - name: document.getElementById('albumName').value - }) - .then(function (response) { - - if(response.data.success === false){ - if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); - else return swal("An error ocurred", response.data.description, "error"); - } - - swal("Woohoo!", "Album was added successfully", "success"); - panel.getAlbumsSidebar(); - panel.getAlbums(); - return; - - }) - .catch(function (error) { - return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); - console.log(error); - }); - -} - -panel.getAlbumsSidebar = function(){ - - axios.get('/api/albums/sidebar') - .then(function (response) { - if(response.data.success === false){ - if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); - else return swal("An error ocurred", response.data.description, "error"); - } - - var albumsContainer = document.getElementById('albumsContainer'); - albumsContainer.innerHTML = ''; - - if(response.data.albums === undefined) return; - - for(var album of response.data.albums){ - - li = document.createElement('li'); - a = document.createElement('a'); - a.id = album.id; - a.innerHTML = album.name; - - a.addEventListener('click', function(){ - panel.getAlbum(this); - }); - - li.appendChild(a); - albumsContainer.appendChild(li); - } - - - }) - .catch(function (error) { - return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); - console.log(error); - }); - -} - -panel.getAlbum = function(item){ - panel.setActiveMenu(item); - panel.getUploads(item.id); -} - -panel.changeToken = function(){ - - axios.get('/api/tokens') - .then(function (response) { - if(response.data.success === false){ - if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); - else return swal("An error ocurred", response.data.description, "error"); - } - - panel.page.innerHTML = ''; - var container = document.createElement('div'); - container.className = "container"; - container.innerHTML = ` -

Manage your token

- - -

- - Request new token -

- `; - - panel.page.appendChild(container); - - document.getElementById('getNewToken').addEventListener('click', function(){ - panel.getNewToken(); - }); - - }) - .catch(function (error) { - return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); - console.log(error); - }); - -} - -panel.getNewToken = function(){ - - axios.post('/api/tokens/change') - .then(function (response) { - - if(response.data.success === false){ - if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); - else return swal("An error ocurred", response.data.description, "error"); - } - - swal({ - title: "Woohoo!", - text: 'Your token was changed successfully.', - type: "success" - }, function(){ - localStorage.token = response.data.token; - location.reload(); - }) - - }) - .catch(function (error) { - return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); - console.log(error); - }); - -} - -panel.changePassword = function(){ - - panel.page.innerHTML = ''; - var container = document.createElement('div'); - container.className = "container"; - container.innerHTML = ` -

Change your password

- - -

- - Set new password -

- `; - - panel.page.appendChild(container); - - document.getElementById('sendChangePassword').addEventListener('click', function(){ - panel.sendNewPassword(document.getElementById('password').value); - }); - -} - -panel.sendNewPassword = function(pass){ - - axios.post('/api/password/change', {password: pass}) - .then(function (response) { - - if(response.data.success === false){ - if(response.data.description === 'No token provided') return panel.verifyToken(panel.token); - else return swal("An error ocurred", response.data.description, "error"); - } - - swal({ - title: "Woohoo!", - text: 'Your password was changed successfully.', - type: "success" - }, function(){ - location.reload(); - }) - - }) - .catch(function (error) { - return swal("An error ocurred", 'There was an error with the request, please check the console for more information.', "error"); - console.log(error); - }); - -} - -panel.setActiveMenu = function(item){ - var menu = document.getElementById('menu'); - var items = menu.getElementsByTagName('a'); - for(var i = 0; i < items.length; i++) - items[i].className = ""; - - item.className = 'is-active'; -} - -window.onload = function () { - panel.preparePage(); -} -- cgit v1.2.3