apiRequest

This commit is contained in:
Sebastian Frank 2017-08-24 15:55:44 +02:00
parent 931c142e16
commit 06db9fa762
No known key found for this signature in database
GPG Key ID: DC2BC5C506EBF6F3
4 changed files with 159 additions and 47 deletions

View File

@ -1,9 +1,13 @@
{ {
"baseURL": "https://cx20.basispanel.de/api/v1/", "api": {
"APItargets": { "baseURL": "https://cx20.basehosts.de/api/v1/"
"login": "login"
}, },
"navigation": [ "navigation": [
{
"name": "Login",
"to": "/login",
"icon": "fa-home"
},
{ {
"name": "Dashboard", "name": "Dashboard",
"to": "/", "to": "/",

View File

@ -0,0 +1,37 @@
<template>
<div class="LoginForm">
<h2>Login</h2>
<form @submit.prevent="login">
<label>Username:</label><input type="text" v-model="username"><br>
<label>Password:</label><input type="password" v-model="password"><br>
<input type="submit" value="login">
</form>
</div>
</template>
<script>
import Axios from 'axios';
export default {
name: 'LoginForm',
data() {
return {
username: '',
password: ''
}
},
methods: {
login() {
this.$store.dispatch("login", this.$data)
.then(user => {
console.log("---- user login --------");
console.log(user);
})
.catch(error => {
console.log("---- login error -------");
console.log(error);
});
}
}
}
</script>

View File

@ -18,30 +18,26 @@ export default {
return { return {
columns: [ columns: [
{ {
heading: 'col1', heading: 'ID',
prop: 'prop1' prop: 'ID'
}, },
{ {
heading: 'col2', heading: 'Benutzername',
prop: 'prop2' prop: 'Username'
}, }
{
heading: 'col3',
prop: 'prop3'
},
], ],
rows: [ rows: [
{prop1: 'r1p1', prop2: 'r1p2', prop3: 'r1p3'},
{prop1: 'r2p1', prop2: 'r2p2', prop3: 'r2p3'},
{prop1: 'r3p1', prop2: 'r3p2', prop3: 'r3p3'},
{prop1: 'r4p1', prop2: 'r4p2', prop3: 'r4p3'},
] ]
} }
}, },
methods: { created() {
add() { this.$store.dispatch('apiRequest', {
this.rows.push({'prop1': 'test'}); endpoint: 'users'
} })
.then(rows => this.rows = rows)
.catch(error => {
console.log(error);
});
} }
} }
</script> </script>

View File

@ -5,6 +5,7 @@ import Axios from 'axios';
import App from './app.vue'; import App from './app.vue';
import Dashboard from './components/dashboard.vue'; import Dashboard from './components/dashboard.vue';
import LoginForm from './components/forms/login.vue';
import Userlist from './components/userlist.vue'; import Userlist from './components/userlist.vue';
Vue.use(VueRouter); Vue.use(VueRouter);
@ -12,12 +13,85 @@ Vue.use(Vuex);
const store = new Vuex.Store({ const store = new Vuex.Store({
state: { state: {
api: {},
navigation: [],
login: {},
authToken: '',
credentials: {}
}, },
mutations: { mutations: {
setAPI(state, payload) {
state.api = payload;
},
setNavigation(state, payload) {
for (var i=0; i<payload.length; i++) {
state.navigation.push(payload[i]); // = payload;
}
},
setCredentials(state, payload) {
state.credentials = {
username: payload.username,
password: payload.password
}
},
setLogin(state, payload) {
state.login = payload.User;
state.authToken = payload.AuthToken;
}
},
actions: {
apiRequest(context, payload) {
return new Promise((resolve, reject) => {
let endpoint = context.state.api.baseURL + payload.endpoint;
Axios({
method: payload.method ? payload.method : 'get',
url: endpoint,
data: payload.data,
headers: {
'X-Auth-Token': context.state.authToken
} }
}) })
.then(response => {
console.log(response);
resolve(response.data);
})
.catch(error => {
console.dir(error);
reject(error);
})
});
},
login(context, payload) {
context.commit('setCredentials', payload);
return new Promise((resolve, reject) => {
context.dispatch('apiRequest', {
method: 'post',
endpoint: 'login',
data: payload
})
.then(data => {
context.commit('setLogin', data);
resolve(data.User);
})
.catch(error => {
if (error.response && error.response.data && error.response.data.error) {
reject(error.response.data.error);
} else {
reject([]);
}
});
});
}
}
});
const routes = [ const routes = [
{
path: '/login',
component: LoginForm
},
{ {
path: '/', path: '/',
component: Dashboard component: Dashboard
@ -32,31 +106,32 @@ const router = new VueRouter({
routes routes
}); });
// load init
Axios.get('conf/init.json')
.then(results => {
// set navigation
if ( !Array.isArray(results.data.navigation) ) {
alert('invalid data in: ' + this.src);
return;
}
store.commit("setNavigation", results.data.navigation);
// set api config in store
store.commit("setAPI", results.data.api);
// load app, when init finishs
new Vue({ new Vue({
el: '#vue-app', el: '#vue-app',
components: { components: {
App App
}, },
data: { data: {
navItems: [ ] navItems: store.state.navigation
}, },
router, router,
store, store
created() { });
// load init
Axios.get('conf/init.json')
.then(results => {
if ( !Array.isArray(results.data.navigation) ) {
alert('invalid data in: ' + this.src);
return;
}
// add routes
this.navItems = results.data.navigation;
}) })
.catch(error => { .catch(error => {
alert('error loading ' + this.src + ': ' + error.message); alert('error loading: ' + error.message);
});
}
}); });