]> git.immae.eu Git - perso/Immae/Projets/Nodejs/Surfer.git/blame - app/js/app.js
Move admin ui to _admin to avoid less likely conflict
[perso/Immae/Projets/Nodejs/Surfer.git] / app / js / app.js
CommitLineData
6eb72d64
JZ
1(function () {
2'use strict';
3
4function login(username, password) {
5 username = username || app.loginData.username;
6 password = password || app.loginData.password;
7
8 app.busy = true;
9
10 superagent.get('/api/files/').query({ username: username, password: password }).end(function (error, result) {
11 app.busy = false;
12
13 if (error) return console.error(error);
14 if (result.statusCode === 401) return console.error('Invalid credentials');
15
16 app.session.valid = true;
17 app.session.username = username;
18 app.session.password = password;
19
20 // clearly not the best option
21 localStorage.username = username;
22 localStorage.password = password;
d3312ed1
JZ
23
24 loadDirectory(app.path);
6eb72d64
JZ
25 });
26}
27
28function logout() {
29 app.session.valid = false;
30 app.session.username = username;
31 app.session.password = password;
32
33 delete localStorage.username;
34 delete localStorage.password;
35}
36
d3312ed1
JZ
37function sanitize(filePath) {
38 filePath = '/' + filePath;
39 return filePath.replace(/\/+/g, '/');
40}
41
537bfb04
JZ
42function encode(filePath) {
43 return filePath.split('/').map(encodeURIComponent).join('/');
44}
45
46function refresh() {
47 loadDirectory(app.path);
48}
49
d3312ed1
JZ
50function loadDirectory(filePath) {
51 app.busy = true;
52
53 filePath = filePath ? sanitize(filePath) : '/';
54
55 console.log(filePath);
56
57 superagent.get('/api/files/' + filePath).query({ username: app.session.username, password: app.session.password }).end(function (error, result) {
58 app.busy = false;
59
60 if (error) return console.error(error);
61 if (result.statusCode === 401) return logout();
62
63 app.entries = result.body.entries;
64 app.path = filePath;
65 app.pathParts = filePath.split('/').filter(function (e) { return !!e; });
d3312ed1
JZ
66 });
67}
68
69function open(entry) {
70 var path = sanitize(app.path + '/' + entry.filePath);
71
72 if (entry.isDirectory) return loadDirectory(path);
73
ee9d1ada 74 window.open(path);
d3312ed1
JZ
75}
76
77function up() {
78 loadDirectory(app.path.split('/').slice(0, -1).filter(function (p) { return !!p; }).join('/'));
79}
80
537bfb04
JZ
81function upload() {
82 $(app.$els.upload).change(function () {
83 app.busy = true;
84
85 var file = app.$els.upload.files[0];
86 var path = encode(sanitize(app.path + '/' + file.name));
87
88 var formData = new FormData();
89 formData.append('file', file);
90
91 superagent.put('/api/files' + path).query({ username: app.session.username, password: app.session.password }).send(formData).end(function (error, result) {
92 app.busy = false;
93
94 if (error) return console.error(error);
95 if (result.statusCode !== 201) return console.error('Error uploading file: ', result.statusCode);
96
97 refresh();
98 });
99 });
100
101 app.$els.upload.click();
102}
103
9138d7d4
JZ
104function delAsk(entry) {
105 $('#modalDelete').modal('show');
106 app.deleteData = entry;
107}
108
109function del(entry) {
110 app.busy = true;
111
112 var path = encode(sanitize(app.path + '/' + entry.filePath));
113
114 superagent.del('/api/files' + path).query({ username: app.session.username, password: app.session.password, recursive: true }).end(function (error, result) {
115 app.busy = false;
116
117 if (error) return console.error(error);
118 if (result.statusCode !== 200) return console.error('Error deleting file: ', result.statusCode);
119
120 refresh();
121
122 $('#modalDelete').modal('hide');
123 });
124}
125
6eb72d64
JZ
126var app = new Vue({
127 el: '#app',
128 data: {
129 busy: true,
d3312ed1
JZ
130 path: '/',
131 pathParts: [],
6eb72d64
JZ
132 session: {
133 valid: false
134 },
d3312ed1 135 loginData: {},
9138d7d4 136 deleteData: {},
d3312ed1 137 entries: []
6eb72d64
JZ
138 },
139 methods: {
140 login: login,
d3312ed1
JZ
141 logout: logout,
142 loadDirectory: loadDirectory,
143 open: open,
537bfb04 144 up: up,
9138d7d4
JZ
145 upload: upload,
146 delAsk: delAsk,
147 del: del
6eb72d64
JZ
148 }
149});
150
151window.app = app;
152
153login(localStorage.username, localStorage.password);
154
155})();