Merge branch 'feature/useroptions' into develop
This commit is contained in:
commit
4642d58a2c
|
@ -920,6 +920,16 @@
|
||||||
"postcss": "^7.0.0"
|
"postcss": "^7.0.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"@mdi/font": {
|
||||||
|
"version": "4.8.95",
|
||||||
|
"resolved": "https://registry.npmjs.org/@mdi/font/-/font-4.8.95.tgz",
|
||||||
|
"integrity": "sha512-mfEjd6kkuheZ15CBU7g/q+De9+dah/SEgVH0uZsgCJTSYa+CkXIen35aNyHoixgcEfPV4Or0NLJvyYM5CXUnbQ=="
|
||||||
|
},
|
||||||
|
"@mdi/js": {
|
||||||
|
"version": "4.8.95",
|
||||||
|
"resolved": "https://registry.npmjs.org/@mdi/js/-/js-4.8.95.tgz",
|
||||||
|
"integrity": "sha512-mKhC18fKPtSNJxpHa6tHmntnLjSUSrzOIuT4QnhlXt27MkOP5n+sQtK6Ii/R0K4fdpgLZGi+vR5o6PsDDb/iIg=="
|
||||||
|
},
|
||||||
"@mrmlnc/readdir-enhanced": {
|
"@mrmlnc/readdir-enhanced": {
|
||||||
"version": "2.2.1",
|
"version": "2.2.1",
|
||||||
"resolved": "https://registry.npmjs.org/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz",
|
"resolved": "https://registry.npmjs.org/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz",
|
||||||
|
|
|
@ -8,6 +8,8 @@
|
||||||
"lint": "vue-cli-service lint"
|
"lint": "vue-cli-service lint"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"@mdi/font": "^4.8.95",
|
||||||
|
"@mdi/js": "^4.8.95",
|
||||||
"core-js": "^3.4.3",
|
"core-js": "^3.4.3",
|
||||||
"vue": "^2.6.10",
|
"vue": "^2.6.10",
|
||||||
"vue-router": "^3.1.3",
|
"vue-router": "^3.1.3",
|
||||||
|
|
|
@ -5,23 +5,31 @@
|
||||||
</v-btn>
|
</v-btn>
|
||||||
<v-toolbar-title>WU5-Dashboard</v-toolbar-title>
|
<v-toolbar-title>WU5-Dashboard</v-toolbar-title>
|
||||||
<v-spacer />
|
<v-spacer />
|
||||||
<v-btn icon v-if="isFinanzer" href="finanzer">
|
<v-btn icon v-if="isFinanzer">
|
||||||
<v-icon>attach_money</v-icon>
|
<v-icon>{{attach_money}}</v-icon>
|
||||||
</v-btn>
|
</v-btn>
|
||||||
<v-btn icon v-if="isBar">
|
<v-btn icon v-if="isBar">
|
||||||
<v-icon>local_bar</v-icon>
|
<v-icon>{{local_bar}}</v-icon>
|
||||||
</v-btn>
|
</v-btn>
|
||||||
<v-btn icon v-if="isUser">
|
<v-btn icon v-if="isUser">
|
||||||
<v-icon>person</v-icon>
|
<v-icon>{{person}}</v-icon>
|
||||||
</v-btn>
|
</v-btn>
|
||||||
</v-app-bar>
|
</v-app-bar>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { mapActions, mapGetters } from 'vuex'
|
import { mapActions, mapGetters } from 'vuex'
|
||||||
|
import { mdiCurrencyEur, mdiGlassCocktail, mdiAccount } from '@mdi/js'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'TitleBar',
|
name: 'TitleBar',
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
attach_money: mdiCurrencyEur,
|
||||||
|
local_bar: mdiGlassCocktail,
|
||||||
|
person: mdiAccount
|
||||||
|
}
|
||||||
|
},
|
||||||
computed: {
|
computed: {
|
||||||
...mapGetters(['isBar', 'isFinanzer', 'isUser', 'isLoggedIn'])
|
...mapGetters(['isBar', 'isFinanzer', 'isUser', 'isLoggedIn'])
|
||||||
},
|
},
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
<v-list>
|
<v-list>
|
||||||
<v-list-item link to="/main/bar/geruecht">
|
<v-list-item link to="/main/bar/geruecht">
|
||||||
<v-list-item-icon>
|
<v-list-item-icon>
|
||||||
<v-icon>local_drink</v-icon>
|
<v-icon>{{ glass_mug_variant }}</v-icon>
|
||||||
</v-list-item-icon>
|
</v-list-item-icon>
|
||||||
<v-list-item-title>
|
<v-list-item-title>
|
||||||
Geruecht
|
Geruecht
|
||||||
|
@ -12,8 +12,14 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
import { mdiGlassMugVariant } from '@mdi/js'
|
||||||
export default {
|
export default {
|
||||||
name: 'BarNavigation'
|
name: 'BarNavigation',
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
glass_mug_variant: mdiGlassMugVariant
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,13 @@
|
||||||
<template>
|
<template>
|
||||||
<div>
|
<div>
|
||||||
|
<v-progress-linear v-if="loading && users.length !== 0" indeterminate />
|
||||||
|
<v-container>
|
||||||
|
<AddAmountSkeleton v-if="loading && users.length === 0" />
|
||||||
|
</v-container>
|
||||||
<div v-for="user in users" :key="users.indexOf(user)">
|
<div v-for="user in users" :key="users.indexOf(user)">
|
||||||
<div v-if="isFiltered(user)">
|
<div v-if="isFiltered(user)">
|
||||||
<v-container>
|
<v-container>
|
||||||
<v-card>
|
<v-card :loading="user.loading">
|
||||||
<v-list-item>
|
<v-list-item>
|
||||||
<v-list-item-title class="title"
|
<v-list-item-title class="title"
|
||||||
>{{ user.firstname }} {{ user.lastname }}</v-list-item-title
|
>{{ user.firstname }} {{ user.lastname }}</v-list-item-title
|
||||||
|
@ -117,9 +121,11 @@
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { mapGetters, mapActions } from 'vuex'
|
import { mapGetters, mapActions } from 'vuex'
|
||||||
|
import AddAmountSkeleton from '../user/Skeleton/AddAmountSkeleton'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'CreditLists',
|
name: 'CreditLists',
|
||||||
|
components: { AddAmountSkeleton },
|
||||||
props: {},
|
props: {},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
@ -151,7 +157,8 @@ export default {
|
||||||
computed: {
|
computed: {
|
||||||
...mapGetters({
|
...mapGetters({
|
||||||
users: 'barUsers/users',
|
users: 'barUsers/users',
|
||||||
filter: 'barUsers/filter'
|
filter: 'barUsers/filter',
|
||||||
|
loading: 'barUsers/usersLoading'
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,10 +11,14 @@
|
||||||
placeholder="Suche Person"
|
placeholder="Suche Person"
|
||||||
:items="allUsers"
|
:items="allUsers"
|
||||||
item-text="fullName"
|
item-text="fullName"
|
||||||
prepend-inner-icon="search"
|
|
||||||
full-width
|
full-width
|
||||||
|
:loading="loading"
|
||||||
:search-input.sync="filter"
|
:search-input.sync="filter"
|
||||||
/>
|
>
|
||||||
|
<template v-slot:prepend-inner>
|
||||||
|
<v-icon>{{search_person}}</v-icon>
|
||||||
|
</template>
|
||||||
|
</v-autocomplete>
|
||||||
<v-btn text @click="addUser">Hinzufügen</v-btn>
|
<v-btn text @click="addUser">Hinzufügen</v-btn>
|
||||||
</v-toolbar-items>
|
</v-toolbar-items>
|
||||||
</v-toolbar>
|
</v-toolbar>
|
||||||
|
@ -23,6 +27,7 @@
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { mapGetters, mapActions } from 'vuex'
|
import { mapGetters, mapActions } from 'vuex'
|
||||||
|
import { mdiAccountSearch } from '@mdi/js'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'SearchBar',
|
name: 'SearchBar',
|
||||||
|
@ -30,7 +35,8 @@ export default {
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
user: null,
|
user: null,
|
||||||
filter: ''
|
filter: '',
|
||||||
|
search_person: mdiAccountSearch
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
|
@ -48,7 +54,10 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
...mapGetters({ allUsers: 'barUsers/allUsers' })
|
...mapGetters({
|
||||||
|
allUsers: 'barUsers/allUsers',
|
||||||
|
loading: 'barUsers/allUsersLoading'
|
||||||
|
})
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
filter(val) {
|
filter(val) {
|
||||||
|
|
|
@ -1,23 +1,17 @@
|
||||||
<template>
|
<template>
|
||||||
<div>
|
<div>
|
||||||
<v-list>
|
<v-list>
|
||||||
<v-list-item
|
<v-list-item class="title" link to="/main/finanzer/overview">
|
||||||
class="title"
|
|
||||||
link
|
|
||||||
to="/main/finanzer/overview"
|
|
||||||
>
|
|
||||||
<v-list-item-icon>
|
<v-list-item-icon>
|
||||||
<v-icon>home</v-icon>
|
<v-icon>{{home}}</v-icon>
|
||||||
</v-list-item-icon>
|
</v-list-item-icon>
|
||||||
<v-list-item-title>Gesamtübersicht</v-list-item-title>
|
<v-list-item-title>Gesamtübersicht</v-list-item-title>
|
||||||
</v-list-item>
|
</v-list-item>
|
||||||
<v-list-item link to="/main/finanzer/servicemanagement">
|
<v-list-item link to="/main/finanzer/servicemanagement">
|
||||||
<v-list-item-icon>
|
<v-list-item-icon>
|
||||||
<v-icon>work</v-icon>
|
<v-icon>{{work}}</v-icon>
|
||||||
</v-list-item-icon>
|
</v-list-item-icon>
|
||||||
<v-list-item-title>
|
<v-list-item-title>Dienstverwaltung</v-list-item-title>
|
||||||
Dienstverwaltung
|
|
||||||
</v-list-item-title>
|
|
||||||
</v-list-item>
|
</v-list-item>
|
||||||
</v-list>
|
</v-list>
|
||||||
<v-divider />
|
<v-divider />
|
||||||
|
@ -28,27 +22,38 @@
|
||||||
link
|
link
|
||||||
>
|
>
|
||||||
<v-list-item-title
|
<v-list-item-title
|
||||||
>{{ user.lastname }}, {{ user.firstname }}
|
>{{ user.lastname }}, {{ user.firstname }}</v-list-item-title
|
||||||
</v-list-item-title>
|
>
|
||||||
</v-list-item>
|
</v-list-item>
|
||||||
</div>
|
</div>
|
||||||
|
<v-list-item>
|
||||||
|
<v-progress-circular indeterminate color="grey" v-if="loading" />
|
||||||
|
</v-list-item>
|
||||||
</v-list>
|
</v-list>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { mapGetters, mapActions } from 'vuex'
|
import { mapGetters, mapActions } from 'vuex'
|
||||||
|
import {mdiHome, mdiBriefcase} from '@mdi/js'
|
||||||
export default {
|
export default {
|
||||||
name: 'FinanzerNavigation',
|
name: 'FinanzerNavigation',
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
home: mdiHome,
|
||||||
|
work: mdiBriefcase
|
||||||
|
}
|
||||||
|
},
|
||||||
methods: {
|
methods: {
|
||||||
...mapActions({
|
...mapActions({
|
||||||
addUser: 'finanzerUsers/addUser',
|
addUser: 'finanzerUsers/addUser'
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
...mapGetters({
|
...mapGetters({
|
||||||
users: 'finanzerUsers/users',
|
users: 'finanzerUsers/users',
|
||||||
allUsers: 'finanzerUsers/allUsers'
|
allUsers: 'finanzerUsers/allUsers',
|
||||||
|
loading: 'finanzerUsers/usersLoading'
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,13 +5,13 @@
|
||||||
<v-spacer />
|
<v-spacer />
|
||||||
<v-toolbar-items>
|
<v-toolbar-items>
|
||||||
<v-btn text icon @click="countYear(false)">
|
<v-btn text icon @click="countYear(false)">
|
||||||
<v-icon>keyboard_arrow_left</v-icon>
|
<v-icon>{{keyboard_arrow_left}}</v-icon>
|
||||||
</v-btn>
|
</v-btn>
|
||||||
<v-list-item>
|
<v-list-item>
|
||||||
<v-list-item-title class="title">{{ year }}</v-list-item-title>
|
<v-list-item-title class="title">{{ year }}</v-list-item-title>
|
||||||
</v-list-item>
|
</v-list-item>
|
||||||
<v-btn text icon @click="countYear(true)" :disabled="isActualYear">
|
<v-btn text icon @click="countYear(true)" :disabled="isActualYear">
|
||||||
<v-icon>keyboard_arrow_right</v-icon>
|
<v-icon>{{keyboard_arrow_right}}</v-icon>
|
||||||
</v-btn>
|
</v-btn>
|
||||||
</v-toolbar-items>
|
</v-toolbar-items>
|
||||||
<v-spacer />
|
<v-spacer />
|
||||||
|
@ -25,10 +25,14 @@
|
||||||
placeholder="Suche Person"
|
placeholder="Suche Person"
|
||||||
:items="allUsers"
|
:items="allUsers"
|
||||||
item-text="fullName"
|
item-text="fullName"
|
||||||
prepend-inner-icon="search"
|
|
||||||
full-width
|
full-width
|
||||||
|
:loading="allUsersLoading"
|
||||||
:search-input.sync="filter"
|
:search-input.sync="filter"
|
||||||
/>
|
>
|
||||||
|
<template v-slot:prepend-inner>
|
||||||
|
<v-icon>{{search_person}}</v-icon>
|
||||||
|
</template>
|
||||||
|
</v-autocomplete>
|
||||||
<v-btn
|
<v-btn
|
||||||
text
|
text
|
||||||
@click="addToUser(user)"
|
@click="addToUser(user)"
|
||||||
|
@ -62,10 +66,13 @@
|
||||||
</v-expand-transition>
|
</v-expand-transition>
|
||||||
</v-card>
|
</v-card>
|
||||||
</v-expand-transition>
|
</v-expand-transition>
|
||||||
|
<v-progress-linear v-if="loading && users.length !== 0" indeterminate />
|
||||||
|
<TableSkeleton v-if="loading && users.length === 0" />
|
||||||
<div v-for="user in users" :key="users.indexOf(user)">
|
<div v-for="user in users" :key="users.indexOf(user)">
|
||||||
<v-card
|
<v-card
|
||||||
v-if="user.creditList[year] && isFiltered(user)"
|
v-if="user.creditList[year] && isFiltered(user)"
|
||||||
style="margin-top: 3px"
|
style="margin-top: 3px"
|
||||||
|
:loading="user.loading"
|
||||||
>
|
>
|
||||||
<v-card-title>{{ user.lastname }}, {{ user.firstname }}</v-card-title>
|
<v-card-title>{{ user.lastname }}, {{ user.firstname }}</v-card-title>
|
||||||
<Table v-bind:user="user" v-bind:year="year" />
|
<Table v-bind:user="user" v-bind:year="year" />
|
||||||
|
@ -206,12 +213,17 @@
|
||||||
<script>
|
<script>
|
||||||
import Table from './Table'
|
import Table from './Table'
|
||||||
import { mapGetters, mapActions } from 'vuex'
|
import { mapGetters, mapActions } from 'vuex'
|
||||||
|
import TableSkeleton from './Skeleton/TableSkeleton'
|
||||||
|
import {mdiChevronLeft, mdiChevronRight, mdiAccountSearch} from '@mdi/js'
|
||||||
export default {
|
export default {
|
||||||
name: 'Overview',
|
name: 'Overview',
|
||||||
components: { Table },
|
components: { TableSkeleton, Table },
|
||||||
props: {},
|
props: {},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
keyboard_arrow_left: mdiChevronLeft,
|
||||||
|
keyboard_arrow_right: mdiChevronRight,
|
||||||
|
search_person: mdiAccountSearch,
|
||||||
errorExpand: false,
|
errorExpand: false,
|
||||||
|
|
||||||
filter: '',
|
filter: '',
|
||||||
|
@ -369,7 +381,9 @@ export default {
|
||||||
errorMails: 'finanzerUsers/errorMails',
|
errorMails: 'finanzerUsers/errorMails',
|
||||||
year: 'finanzerUsers/year',
|
year: 'finanzerUsers/year',
|
||||||
years: 'finanzerUsers/years',
|
years: 'finanzerUsers/years',
|
||||||
months: 'finanzerUsers/months'
|
months: 'finanzerUsers/months',
|
||||||
|
loading: 'finanzerUsers/usersLoading',
|
||||||
|
allUsersLoading: 'finanzerUsers/allUsersLoading'
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,60 @@
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<v-card style="margin-top: 3px">
|
||||||
|
<v-card-title>
|
||||||
|
<v-skeleton-loader type="heading" />
|
||||||
|
</v-card-title>
|
||||||
|
<v-container>
|
||||||
|
<v-skeleton-loader type="table-thead"/>
|
||||||
|
<v-skeleton-loader type="table-row-divider@3"/>
|
||||||
|
</v-container>
|
||||||
|
<v-container fluid>
|
||||||
|
<v-row align="start" align-content="start">
|
||||||
|
<v-col>
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip"/>
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
</v-col>
|
||||||
|
<v-col align-self="center">
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
<v-card outlined>
|
||||||
|
<v-row>
|
||||||
|
<v-card-title>
|
||||||
|
<v-skeleton-loader style="margin: 3px; margin-left: 10px" type="chip"/>
|
||||||
|
</v-card-title>
|
||||||
|
</v-row>
|
||||||
|
</v-card>
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
</v-container>
|
||||||
|
</v-card>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: 'TableSkeleton'
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped></style>
|
|
@ -0,0 +1,82 @@
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<v-toolbar tile>
|
||||||
|
<v-toolbar-title>
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
</v-toolbar-title>
|
||||||
|
<v-spacer />
|
||||||
|
<v-toolbar-items>
|
||||||
|
<v-skeleton-loader type="button" />
|
||||||
|
</v-toolbar-items>
|
||||||
|
</v-toolbar>
|
||||||
|
<v-card style="margin-top: 3px;">
|
||||||
|
<v-card-title><v-skeleton-loader type="heading"/></v-card-title>
|
||||||
|
<v-card-text>
|
||||||
|
<v-form style="margin-left: 15px; margin-right: 15px">
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="button" />
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
<v-divider style="margin-bottom: 15px;" />
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
<v-row>
|
||||||
|
<v-skeleton-loader type="button" />
|
||||||
|
</v-row>
|
||||||
|
</v-form>
|
||||||
|
</v-card-text>
|
||||||
|
</v-card>
|
||||||
|
<v-card style="margin-top: 3px;">
|
||||||
|
<v-card-title><v-skeleton-loader type="chip"/></v-card-title>
|
||||||
|
<v-card-text>
|
||||||
|
<v-form style="margin-left: 15px; margin-right: 15px">
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
</v-form>
|
||||||
|
<v-skeleton-loader type="button" />
|
||||||
|
</v-card-text>
|
||||||
|
</v-card>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: 'UserSkeleton'
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped></style>
|
|
@ -1,8 +1,13 @@
|
||||||
<template>
|
<template>
|
||||||
|
<div>
|
||||||
|
<v-content v-if="loading" >
|
||||||
|
<UserSkeleton />
|
||||||
|
</v-content>
|
||||||
<v-content v-if="activeUser">
|
<v-content v-if="activeUser">
|
||||||
<v-toolbar tile>
|
<v-toolbar tile>
|
||||||
<v-toolbar-title
|
<v-toolbar-title
|
||||||
>{{ activeUser.lastname }}, {{ activeUser.firstname }}</v-toolbar-title
|
>{{ activeUser.lastname }},
|
||||||
|
{{ activeUser.firstname }}</v-toolbar-title
|
||||||
>
|
>
|
||||||
<v-spacer />
|
<v-spacer />
|
||||||
<v-toolbar-items>
|
<v-toolbar-items>
|
||||||
|
@ -11,11 +16,12 @@
|
||||||
>
|
>
|
||||||
</v-toolbar-items>
|
</v-toolbar-items>
|
||||||
</v-toolbar>
|
</v-toolbar>
|
||||||
|
<v-progress-linear v-if="activeUser.loading" indeterminate />
|
||||||
<v-expand-transition>
|
<v-expand-transition>
|
||||||
<v-card style="margin-top: 3px" v-show="errorMail">
|
<v-card style="margin-top: 3px" v-show="errorMail">
|
||||||
<v-alert dense :type="computeError(errorMail)">{{
|
<v-alert dense :type="computeError(errorMail)">
|
||||||
errorMessage(errorMail)
|
{{ errorMessage(errorMail) }}
|
||||||
}}</v-alert>
|
</v-alert>
|
||||||
</v-card>
|
</v-card>
|
||||||
</v-expand-transition>
|
</v-expand-transition>
|
||||||
<v-card style="margin-top: 3px;">
|
<v-card style="margin-top: 3px;">
|
||||||
|
@ -27,19 +33,17 @@
|
||||||
<v-label>Status:</v-label>
|
<v-label>Status:</v-label>
|
||||||
</v-col>
|
</v-col>
|
||||||
<v-col>
|
<v-col>
|
||||||
<v-chip
|
<v-chip outlined :text-color="getLockedColor(activeUser.locked)"
|
||||||
outlined
|
>{{ activeUser.locked ? 'Gesperrt' : 'nicht Gesperrt' }}
|
||||||
:text-color="getLockedColor(activeUser.locked)"
|
</v-chip>
|
||||||
>{{ activeUser.locked ? 'Gesperrt' : 'nicht Gesperrt' }}</v-chip
|
|
||||||
>
|
|
||||||
</v-col>
|
</v-col>
|
||||||
<v-col>
|
<v-col>
|
||||||
<v-btn
|
<v-btn
|
||||||
@click="
|
@click="
|
||||||
doLock({ user: activeUser, locked: !activeUser.locked })
|
doLock({ user: activeUser, locked: !activeUser.locked })
|
||||||
"
|
"
|
||||||
>{{ activeUser.locked ? 'Entperren' : 'Sperren' }}</v-btn
|
>{{ activeUser.locked ? 'Entperren' : 'Sperren' }}
|
||||||
>
|
</v-btn>
|
||||||
</v-col>
|
</v-col>
|
||||||
</v-row>
|
</v-row>
|
||||||
<v-divider style="margin-bottom: 15px;" />
|
<v-divider style="margin-bottom: 15px;" />
|
||||||
|
@ -75,8 +79,8 @@
|
||||||
autoLock: autoLock.value
|
autoLock: autoLock.value
|
||||||
})
|
})
|
||||||
"
|
"
|
||||||
>Speichern</v-btn
|
>Speichern
|
||||||
>
|
</v-btn>
|
||||||
</v-row>
|
</v-row>
|
||||||
</v-form>
|
</v-form>
|
||||||
</v-card-text>
|
</v-card-text>
|
||||||
|
@ -149,10 +153,9 @@
|
||||||
:text-color="
|
:text-color="
|
||||||
getLastColor(activeUser.creditList[year][1].last)
|
getLastColor(activeUser.creditList[year][1].last)
|
||||||
"
|
"
|
||||||
>{{
|
|
||||||
(activeUser.creditList[year][1].last / 100).toFixed(2)
|
|
||||||
}}</v-chip
|
|
||||||
>
|
>
|
||||||
|
{{ (activeUser.creditList[year][1].last / 100).toFixed(2) }}
|
||||||
|
</v-chip>
|
||||||
</v-col>
|
</v-col>
|
||||||
<v-col>
|
<v-col>
|
||||||
<v-label>Gesamt:</v-label>
|
<v-label>Gesamt:</v-label>
|
||||||
|
@ -186,17 +189,19 @@
|
||||||
</v-card>
|
</v-card>
|
||||||
</div>
|
</div>
|
||||||
</v-content>
|
</v-content>
|
||||||
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import Table from './Table'
|
import Table from './Table'
|
||||||
import { mapGetters, mapActions } from 'vuex'
|
import { mapGetters, mapActions } from 'vuex'
|
||||||
|
import UserSkeleton from "./Skeleton/UserSkeleton";
|
||||||
export default {
|
export default {
|
||||||
name: 'User',
|
name: 'User',
|
||||||
props: {
|
props: {
|
||||||
id: String
|
id: String
|
||||||
},
|
},
|
||||||
components: { Table },
|
components: {UserSkeleton, Table },
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
isNumber: value => !isNaN(value) || 'Betrag muss eine Zahl sein.',
|
isNumber: value => !isNaN(value) || 'Betrag muss eine Zahl sein.',
|
||||||
|
@ -336,11 +341,13 @@ export default {
|
||||||
activeUser: 'finanzerUsers/activeUser',
|
activeUser: 'finanzerUsers/activeUser',
|
||||||
errorMail: 'finanzerUsers/errorMail',
|
errorMail: 'finanzerUsers/errorMail',
|
||||||
months: 'finanzerUsers/months',
|
months: 'finanzerUsers/months',
|
||||||
selectYears: 'finanzerUsers/selectYears'
|
selectYears: 'finanzerUsers/selectYears',
|
||||||
|
loading: 'finanzerUsers/addUserLoading'
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
activeUser(newVal) {
|
activeUser(newVal) {
|
||||||
|
// eslint-disable-next-line no-console
|
||||||
console.log(newVal)
|
console.log(newVal)
|
||||||
this.limit = (newVal.limit / 100).toFixed(2)
|
this.limit = (newVal.limit / 100).toFixed(2)
|
||||||
this.autoLock = {
|
this.autoLock = {
|
||||||
|
@ -349,6 +356,7 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
id(newVal) {
|
id(newVal) {
|
||||||
|
// eslint-disable-next-line no-console
|
||||||
console.log(newVal)
|
console.log(newVal)
|
||||||
this.setActiveUser(newVal)
|
this.setActiveUser(newVal)
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
<template>
|
<template>
|
||||||
<v-container v-if="user">
|
<v-container >
|
||||||
<v-card>
|
<AddAmountSkeleton v-if="loading" />
|
||||||
|
<v-card v-if="!loading" :loading="addLoading">
|
||||||
<v-list-item>
|
<v-list-item>
|
||||||
<v-list-item-title class="title"
|
<v-list-item-title class="title"
|
||||||
>{{ user.firstname }} {{ user.lastname }}</v-list-item-title
|
>{{ user.firstname }} {{ user.lastname }}</v-list-item-title
|
||||||
|
@ -99,8 +100,10 @@
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import {mapGetters, mapActions} from 'vuex'
|
import {mapGetters, mapActions} from 'vuex'
|
||||||
|
import AddAmountSkeleton from './Skeleton/AddAmountSkeleton'
|
||||||
export default {
|
export default {
|
||||||
name: 'AddAmount',
|
name: 'AddAmount',
|
||||||
|
components: { AddAmountSkeleton },
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
color: 'green accent-4'
|
color: 'green accent-4'
|
||||||
|
@ -123,7 +126,9 @@ export default {
|
||||||
computed: {
|
computed: {
|
||||||
...mapGetters({
|
...mapGetters({
|
||||||
user: 'user/user',
|
user: 'user/user',
|
||||||
year: 'user/year'
|
year: 'user/year',
|
||||||
|
loading: 'user/loading',
|
||||||
|
addLoading: 'user/addLoading'
|
||||||
}),
|
}),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,210 @@
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<v-card v-if="user" :loading="loading" style="margin-top: 3px">
|
||||||
|
<v-card-title>{{ user.firstname }} {{ user.lastname }}</v-card-title>
|
||||||
|
<v-card-text>
|
||||||
|
<v-row>
|
||||||
|
<v-col cols="12" sm="6">
|
||||||
|
<v-text-field
|
||||||
|
outlined
|
||||||
|
label="Vornamen"
|
||||||
|
:placeholder="user.firstname"
|
||||||
|
v-model="firstname"
|
||||||
|
readonly
|
||||||
|
/>
|
||||||
|
</v-col>
|
||||||
|
<v-col cols="12" sm="6">
|
||||||
|
<v-text-field
|
||||||
|
outlined
|
||||||
|
label="Nachname"
|
||||||
|
:placeholder="user.lastname"
|
||||||
|
v-model="lastname"
|
||||||
|
readonly
|
||||||
|
/>
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
<v-row>
|
||||||
|
<v-col cols="12" sm="6">
|
||||||
|
<v-text-field
|
||||||
|
outlined
|
||||||
|
label="Benutzername"
|
||||||
|
:placeholder="user.username"
|
||||||
|
v-model="username"
|
||||||
|
readonly
|
||||||
|
></v-text-field>
|
||||||
|
</v-col>
|
||||||
|
<v-col cols="12" sm="6">
|
||||||
|
<v-text-field
|
||||||
|
ref="mail"
|
||||||
|
outlined
|
||||||
|
label="E-Mail"
|
||||||
|
:placeholder="user.mail"
|
||||||
|
v-model="mail"
|
||||||
|
readonly
|
||||||
|
></v-text-field>
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
<v-row>
|
||||||
|
<v-col cols="12" sm="6">
|
||||||
|
<v-text-field
|
||||||
|
outlined
|
||||||
|
label="Password"
|
||||||
|
type="password"
|
||||||
|
v-model="password"
|
||||||
|
/>
|
||||||
|
</v-col>
|
||||||
|
<v-col cols="12" sm="6">
|
||||||
|
<v-text-field
|
||||||
|
ref="password"
|
||||||
|
outlined
|
||||||
|
label="Password bestätigen"
|
||||||
|
type="password"
|
||||||
|
:disabled="!password"
|
||||||
|
:rules="[equal_password]"
|
||||||
|
/>
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
<v-divider />
|
||||||
|
<v-row>
|
||||||
|
<v-col cols="12" sm="4">
|
||||||
|
<v-text-field
|
||||||
|
outlined
|
||||||
|
label="Sperrlimit"
|
||||||
|
readonly
|
||||||
|
:value="(user.limit / 100).toFixed(2).toString() + '€'"
|
||||||
|
/>
|
||||||
|
</v-col>
|
||||||
|
<v-col cols="12" sm="4">
|
||||||
|
<v-combobox
|
||||||
|
outlined
|
||||||
|
label="Sperrstatus"
|
||||||
|
v-model="lock"
|
||||||
|
append-icon
|
||||||
|
readonly
|
||||||
|
>
|
||||||
|
<template v-slot:selection="data">
|
||||||
|
<v-chip :color="lockColor">
|
||||||
|
{{ data.item }}
|
||||||
|
</v-chip>
|
||||||
|
</template>
|
||||||
|
</v-combobox>
|
||||||
|
</v-col>
|
||||||
|
<v-col cols="12" sm="4">
|
||||||
|
<v-combobox
|
||||||
|
outlined
|
||||||
|
label="Autosperre"
|
||||||
|
v-model="autoLock"
|
||||||
|
readonly
|
||||||
|
append-icon
|
||||||
|
>
|
||||||
|
<template v-slot:selection="data">
|
||||||
|
<v-chip :color="autoLockColor">
|
||||||
|
{{ data.item }}
|
||||||
|
</v-chip>
|
||||||
|
</template>
|
||||||
|
</v-combobox>
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<v-combobox
|
||||||
|
outlined
|
||||||
|
multiple
|
||||||
|
label="Gruppen"
|
||||||
|
readonly
|
||||||
|
v-model="user.group"
|
||||||
|
append-icon
|
||||||
|
>
|
||||||
|
<template v-slot:selection="data">
|
||||||
|
<v-icon>{{
|
||||||
|
data.item === 'user'
|
||||||
|
? person
|
||||||
|
: data.item === 'bar'
|
||||||
|
? bar
|
||||||
|
: data.item === 'moneymaster'
|
||||||
|
? finanzer
|
||||||
|
: false
|
||||||
|
}}</v-icon>
|
||||||
|
</template>
|
||||||
|
</v-combobox>
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
</v-card-text>
|
||||||
|
<v-card-actions>
|
||||||
|
<v-spacer></v-spacer>
|
||||||
|
<v-btn @click="save">Save</v-btn>
|
||||||
|
</v-card-actions>
|
||||||
|
<v-expand-transition>
|
||||||
|
<v-alert type="error" v-if="error">{{error}}</v-alert>
|
||||||
|
</v-expand-transition>
|
||||||
|
</v-card>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import { mdiAccount, mdiGlassCocktail, mdiCurrencyEur } from '@mdi/js'
|
||||||
|
import { mapGetters, mapActions } from 'vuex'
|
||||||
|
export default {
|
||||||
|
name: 'Config',
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
person: mdiAccount,
|
||||||
|
bar: mdiGlassCocktail,
|
||||||
|
finanzer: mdiCurrencyEur,
|
||||||
|
username: null,
|
||||||
|
mail: null,
|
||||||
|
firstname: null,
|
||||||
|
lastname: null,
|
||||||
|
password: null,
|
||||||
|
equal_password: value =>
|
||||||
|
this.password === value || 'Passwörter sind nicht identisch.',
|
||||||
|
email: value => {
|
||||||
|
if(value.length > 0) {
|
||||||
|
const pattern = /^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
|
||||||
|
return pattern.test(value) || 'keine gültige E-Mail';
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
...mapActions({
|
||||||
|
saveConfig: 'user/saveConfig'
|
||||||
|
}),
|
||||||
|
save() {
|
||||||
|
let user = {}
|
||||||
|
if (this.firstname) user.firstname = this.firstname
|
||||||
|
if (this.lastname) user.lastname = this.lastname
|
||||||
|
if (this.username) user.username = this.username
|
||||||
|
if (this.$refs.mail.validate()) {
|
||||||
|
if (this.mail) user.mail = this.mail
|
||||||
|
}
|
||||||
|
if (this.$refs.password.validate()) {
|
||||||
|
if (this.password) user.password = this.password
|
||||||
|
}
|
||||||
|
this.saveConfig({oldUsername: user.username, ...user})
|
||||||
|
}
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
...mapGetters({
|
||||||
|
user: 'user/user',
|
||||||
|
error: 'user/error',
|
||||||
|
loading: 'user/loading'
|
||||||
|
}),
|
||||||
|
lock() {
|
||||||
|
return this.user.locked ? 'gesperrt' : 'nicht gesperrt'
|
||||||
|
},
|
||||||
|
lockColor() {
|
||||||
|
return this.user.locked ? 'red' : 'green'
|
||||||
|
},
|
||||||
|
autoLock() {
|
||||||
|
return this.user.autoLock ? 'aktiviert' : 'deaktiviert'
|
||||||
|
},
|
||||||
|
autoLockColor() {
|
||||||
|
return this.user.autoLock ? 'green' : 'red'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped></style>
|
|
@ -7,12 +7,17 @@
|
||||||
<v-text-field
|
<v-text-field
|
||||||
v-model="filter"
|
v-model="filter"
|
||||||
style="margin-top: 3px"
|
style="margin-top: 3px"
|
||||||
append-icon="search"
|
|
||||||
outlined
|
outlined
|
||||||
|
type="number"
|
||||||
:rules="[isNumber]"
|
:rules="[isNumber]"
|
||||||
></v-text-field>
|
>
|
||||||
|
<template v-slot:append>
|
||||||
|
<v-icon>{{magnify}}</v-icon>
|
||||||
|
</template>
|
||||||
|
</v-text-field>
|
||||||
</v-toolbar-items>
|
</v-toolbar-items>
|
||||||
</v-toolbar>
|
</v-toolbar>
|
||||||
|
<CreditOverviewSkeleton v-if="loading" />
|
||||||
<div v-for="year in years" :key="years.indexOf(year)">
|
<div v-for="year in years" :key="years.indexOf(year)">
|
||||||
<v-card style="margin-top: 3px" v-if="isFiltered(year)">
|
<v-card style="margin-top: 3px" v-if="isFiltered(year)">
|
||||||
<v-card-title>{{ year }}</v-card-title>
|
<v-card-title>{{ year }}</v-card-title>
|
||||||
|
@ -67,13 +72,16 @@
|
||||||
<script>
|
<script>
|
||||||
import { mapGetters } from 'vuex'
|
import { mapGetters } from 'vuex'
|
||||||
import Table from '../finanzer/Table'
|
import Table from '../finanzer/Table'
|
||||||
|
import CreditOverviewSkeleton from './Skeleton/CreditOverviewSkeleton'
|
||||||
|
import { mdiMagnify } from '@mdi/js'
|
||||||
export default {
|
export default {
|
||||||
name: 'CreditOverview',
|
name: 'CreditOverview',
|
||||||
components: { Table },
|
components: { CreditOverviewSkeleton, Table },
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
isNumber: value => Number.isInteger(parseInt(value === '' ? 0 : value)) || "Muss eine Zahl sein.",
|
isNumber: value => Number.isInteger(parseInt(value === '' ? 0 : value)) || "Muss eine Zahl sein.",
|
||||||
filter: ''
|
filter: '',
|
||||||
|
magnify: mdiMagnify
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
@ -89,7 +97,8 @@ export default {
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
...mapGetters({
|
...mapGetters({
|
||||||
user: 'user/user'
|
user: 'user/user',
|
||||||
|
loading: 'user/loading'
|
||||||
}),
|
}),
|
||||||
years() {
|
years() {
|
||||||
let years = []
|
let years = []
|
||||||
|
|
|
@ -0,0 +1,90 @@
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<v-toolbar>
|
||||||
|
<v-toolbar-title>
|
||||||
|
Dienstübersicht
|
||||||
|
</v-toolbar-title>
|
||||||
|
<v-spacer />
|
||||||
|
<v-toolbar-items>
|
||||||
|
<v-btn text icon @click="changeMonth(-1)">
|
||||||
|
<v-icon>{{ keyboard_arrow_left }}</v-icon>
|
||||||
|
</v-btn>
|
||||||
|
<v-list-item>
|
||||||
|
<v-list-item-title class="title"
|
||||||
|
>{{ date.getDate() }}.{{ date.getMonth() + 1 }}.{{
|
||||||
|
date.getFullYear()
|
||||||
|
}}
|
||||||
|
bis {{ toDate.getDate() }}.{{ toDate.getMonth() + 1 }}.{{
|
||||||
|
toDate.getFullYear()
|
||||||
|
}}
|
||||||
|
</v-list-item-title>
|
||||||
|
</v-list-item>
|
||||||
|
<v-btn text icon @click="changeMonth(1)">
|
||||||
|
<v-icon>{{ keyboard_arrow_right }}</v-icon>
|
||||||
|
</v-btn>
|
||||||
|
</v-toolbar-items>
|
||||||
|
<v-spacer />
|
||||||
|
</v-toolbar>
|
||||||
|
<v-progress-linear indeterminate v-if="loading" />
|
||||||
|
<div v-for="day in days" :key="days.indexOf(day)">
|
||||||
|
<Day v-bind:day="day" style="margin-top: 3px"></Day>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import { mdiChevronLeft, mdiChevronRight } from '@mdi/js'
|
||||||
|
import { mapGetters, mapActions } from 'vuex'
|
||||||
|
import Day from '@/components/user/Jobs/Day'
|
||||||
|
export default {
|
||||||
|
name: 'Jobs',
|
||||||
|
components: { Day },
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
keyboard_arrow_left: mdiChevronLeft,
|
||||||
|
keyboard_arrow_right: mdiChevronRight,
|
||||||
|
date: new Date()
|
||||||
|
}
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
this.createDays(this.date)
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
...mapActions({
|
||||||
|
createDays: 'user/createDays'
|
||||||
|
}),
|
||||||
|
changeMonth(value) {
|
||||||
|
if (value === -1) {
|
||||||
|
this.date = new Date(
|
||||||
|
this.date.getFullYear(),
|
||||||
|
this.date.getMonth(),
|
||||||
|
this.date.getDate() - 1
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
this.date = new Date(
|
||||||
|
this.date.getFullYear(),
|
||||||
|
this.date.getMonth(),
|
||||||
|
this.date.getDate() + 1
|
||||||
|
)
|
||||||
|
}
|
||||||
|
this.createDays(this.date)
|
||||||
|
},
|
||||||
|
test(day) {
|
||||||
|
let index = this.days.indexOf(day)
|
||||||
|
console.log(index, index % 3)
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
...mapGetters({
|
||||||
|
days: 'user/days',
|
||||||
|
loading: 'user/loading'
|
||||||
|
}),
|
||||||
|
toDate() {
|
||||||
|
return new Date(new Date().setDate(this.date.getDate() + 10))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped></style>
|
|
@ -0,0 +1,74 @@
|
||||||
|
<template>
|
||||||
|
<v-card v-if="day.job">
|
||||||
|
<v-card-title
|
||||||
|
>{{ daysArray[day.date.getDay()] }} den {{ day.date.getDate() }}
|
||||||
|
{{ monthArray[day.date.getMonth()] }}
|
||||||
|
{{ day.date.getFullYear() }}
|
||||||
|
</v-card-title>
|
||||||
|
<v-card-text v-if="day.workers.length !== 0">
|
||||||
|
Du hast Dienst mit:
|
||||||
|
<v-chip
|
||||||
|
style="margin: 3px"
|
||||||
|
v-for="person in day.workers"
|
||||||
|
:key="day.workers.indexOf(person)"
|
||||||
|
>{{ person.user.firstname }}
|
||||||
|
{{ person.user.lastname }}
|
||||||
|
</v-chip>
|
||||||
|
</v-card-text>
|
||||||
|
<v-card-text v-else>
|
||||||
|
Du hast alleine Dienst!
|
||||||
|
</v-card-text>
|
||||||
|
</v-card>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import { mapActions } from 'vuex'
|
||||||
|
export default {
|
||||||
|
name: 'Day',
|
||||||
|
props: {
|
||||||
|
day: Object
|
||||||
|
},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
monthArray: [
|
||||||
|
'Januar',
|
||||||
|
'Februar',
|
||||||
|
'März',
|
||||||
|
'April',
|
||||||
|
'Mai',
|
||||||
|
'Juni',
|
||||||
|
'Juli',
|
||||||
|
'August',
|
||||||
|
'September',
|
||||||
|
'Oktober',
|
||||||
|
'November',
|
||||||
|
'Dezember'
|
||||||
|
],
|
||||||
|
daysArray: [
|
||||||
|
'Sonntag',
|
||||||
|
'Montag',
|
||||||
|
'Dienstag',
|
||||||
|
'Mittwoch',
|
||||||
|
'Donnerstag',
|
||||||
|
'Freitag',
|
||||||
|
'Samstag'
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
this.updateDay({ date: this.day.date })
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
...mapActions({
|
||||||
|
updateDay: 'user/updateDay'
|
||||||
|
})
|
||||||
|
},
|
||||||
|
watch: {
|
||||||
|
day() {
|
||||||
|
this.updateDay({ date: this.day.date })
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped></style>
|
|
@ -0,0 +1,50 @@
|
||||||
|
<template>
|
||||||
|
<v-card>
|
||||||
|
<v-card-title>
|
||||||
|
<v-skeleton-loader type="heading" />
|
||||||
|
</v-card-title>
|
||||||
|
<v-card-text>
|
||||||
|
<v-row>
|
||||||
|
<v-col cols="10">
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="button" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="button" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="button" />
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="button" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="button" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="button" />
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
</v-col>
|
||||||
|
<v-col align-self="center">
|
||||||
|
<v-row>
|
||||||
|
<v-list-item>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-list-item>
|
||||||
|
</v-row>
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
</v-card-text>
|
||||||
|
</v-card>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: 'AddAmountSkeleton'
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped></style>
|
|
@ -0,0 +1,35 @@
|
||||||
|
<template>
|
||||||
|
<v-card style="margin-top: 3px">
|
||||||
|
<v-card-title><v-skeleton-loader type="heading"/></v-card-title>
|
||||||
|
<v-container>
|
||||||
|
<v-skeleton-loader type="table-thead" />
|
||||||
|
<v-skeleton-loader type="table-row-divider@3" />
|
||||||
|
</v-container>
|
||||||
|
<v-container fluid>
|
||||||
|
<v-col>
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-skeleton-loader type="chip" />
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
|
</v-col>
|
||||||
|
</v-container>
|
||||||
|
</v-card>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: 'CreditOverviewSkeleton'
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped></style>
|
|
@ -2,7 +2,7 @@
|
||||||
<v-list>
|
<v-list>
|
||||||
<v-list-item link to="/main/user/add">
|
<v-list-item link to="/main/user/add">
|
||||||
<v-list-item-icon>
|
<v-list-item-icon>
|
||||||
<v-icon>home</v-icon>
|
<v-icon>{{account}}</v-icon>
|
||||||
</v-list-item-icon>
|
</v-list-item-icon>
|
||||||
<v-list-item-title>
|
<v-list-item-title>
|
||||||
Home
|
Home
|
||||||
|
@ -10,16 +10,39 @@
|
||||||
</v-list-item>
|
</v-list-item>
|
||||||
<v-list-item link to="/main/user/overview">
|
<v-list-item link to="/main/user/overview">
|
||||||
<v-list-item-icon>
|
<v-list-item-icon>
|
||||||
<v-icon>account_balance</v-icon>
|
<v-icon>{{bank}}</v-icon>
|
||||||
</v-list-item-icon>
|
</v-list-item-icon>
|
||||||
<v-list-item-title>Finanzübersicht</v-list-item-title>
|
<v-list-item-title>Finanzübersicht</v-list-item-title>
|
||||||
</v-list-item>
|
</v-list-item>
|
||||||
|
<v-list-item link to="/main/user/jobs">
|
||||||
|
<v-list-item-icon>
|
||||||
|
<v-icon>
|
||||||
|
{{briefcase}}
|
||||||
|
</v-icon>
|
||||||
|
</v-list-item-icon>
|
||||||
|
<v-list-item-title>Dienstübersicht</v-list-item-title>
|
||||||
|
</v-list-item>
|
||||||
|
<v-list-item link to="/main/user/config">
|
||||||
|
<v-list-item-icon>
|
||||||
|
<v-icon>{{account_card_details}}</v-icon>
|
||||||
|
</v-list-item-icon>
|
||||||
|
<v-list-item-title>Einstellung</v-list-item-title>
|
||||||
|
</v-list-item>
|
||||||
</v-list>
|
</v-list>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
import {mdiAccountCardDetails, mdiHome, mdiBank, mdiBriefcase } from '@mdi/js'
|
||||||
export default {
|
export default {
|
||||||
name: 'UserNavigation'
|
name: 'UserNavigation',
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
account_card_details: mdiAccountCardDetails,
|
||||||
|
account: mdiHome,
|
||||||
|
bank: mdiBank,
|
||||||
|
briefcase: mdiBriefcase
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
<v-spacer />
|
<v-spacer />
|
||||||
<v-toolbar-items>
|
<v-toolbar-items>
|
||||||
<v-btn text icon @click="changeMonth(-1)">
|
<v-btn text icon @click="changeMonth(-1)">
|
||||||
<v-icon>keyboard_arrow_left</v-icon>
|
<v-icon>{{keyboard_arrow_left}}</v-icon>
|
||||||
</v-btn>
|
</v-btn>
|
||||||
<v-list-item>
|
<v-list-item>
|
||||||
<v-list-item-title class="title"
|
<v-list-item-title class="title"
|
||||||
|
@ -17,7 +17,7 @@
|
||||||
>
|
>
|
||||||
</v-list-item>
|
</v-list-item>
|
||||||
<v-btn text icon @click="changeMonth(1)">
|
<v-btn text icon @click="changeMonth(1)">
|
||||||
<v-icon>keyboard_arrow_right</v-icon>
|
<v-icon>{{keyboard_arrow_right}}</v-icon>
|
||||||
</v-btn>
|
</v-btn>
|
||||||
</v-toolbar-items>
|
</v-toolbar-items>
|
||||||
<v-spacer />
|
<v-spacer />
|
||||||
|
@ -47,12 +47,15 @@
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { mapGetters, mapActions } from 'vuex'
|
import { mapGetters, mapActions } from 'vuex'
|
||||||
|
import {mdiChevronLeft, mdiChevronRight} from '@mdi/js'
|
||||||
import Day from './ServiceManagementComponents/Day'
|
import Day from './ServiceManagementComponents/Day'
|
||||||
export default {
|
export default {
|
||||||
name: 'ServiceManagement',
|
name: 'ServiceManagement',
|
||||||
components: { Day },
|
components: { Day },
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
keyboard_arrow_left: mdiChevronLeft,
|
||||||
|
keyboard_arrow_right: mdiChevronRight,
|
||||||
id: 0,
|
id: 0,
|
||||||
date: new Date(),
|
date: new Date(),
|
||||||
monthArray: [
|
monthArray: [
|
||||||
|
@ -91,7 +94,7 @@ export default {
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
...mapGetters({
|
...mapGetters({
|
||||||
month: 'sm/month'
|
month: 'sm/month',
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,12 +1,19 @@
|
||||||
<template>
|
<template>
|
||||||
<div v-if="day">
|
<div v-if="day">
|
||||||
<v-card :color="color(day)" max-width="300px" min-width="300px">
|
<v-card :color="color(day)" max-width="250px" min-width="250px">
|
||||||
<v-card-title v-if="day.date" class="subtitle-1 font-weight-bold">
|
<v-card-title v-if="day.date" class="subtitle-1 font-weight-bold">
|
||||||
{{ day.name }} den {{ day.date.getDate() }}.{{
|
{{ day.name }} den {{ day.date.getDate() }}.{{
|
||||||
day.date.getMonth() + 1
|
day.date.getMonth() + 1
|
||||||
}}.{{ day.date.getFullYear() }}
|
}}.{{ day.date.getFullYear() }}
|
||||||
</v-card-title>
|
</v-card-title>
|
||||||
<v-card-text>
|
<v-card-text>
|
||||||
|
<v-expand-transition>
|
||||||
|
<v-row align="center" justify="center" v-if="day.loading">
|
||||||
|
<v-progress-circular indeterminate color="grey" />
|
||||||
|
</v-row>
|
||||||
|
</v-expand-transition>
|
||||||
|
<v-expand-transition>
|
||||||
|
<div v-show="!day.loading">
|
||||||
<v-autocomplete
|
<v-autocomplete
|
||||||
chips
|
chips
|
||||||
return-object
|
return-object
|
||||||
|
@ -15,10 +22,17 @@
|
||||||
:items="allUsers"
|
:items="allUsers"
|
||||||
item-text="fullName"
|
item-text="fullName"
|
||||||
label="Dienste"
|
label="Dienste"
|
||||||
prepend-inner-icon="group_add"
|
|
||||||
filled
|
filled
|
||||||
color="green"
|
color="green"
|
||||||
|
@input="searchInput=null"
|
||||||
|
:search-input.sync="searchInput"
|
||||||
|
@blur="focused=false"
|
||||||
|
@focus="focused=true"
|
||||||
|
|
||||||
>
|
>
|
||||||
|
<template v-slot:prepend-inner>
|
||||||
|
<v-icon>{{account_add}}</v-icon>
|
||||||
|
</template>
|
||||||
<template v-slot:selection="data">
|
<template v-slot:selection="data">
|
||||||
<v-chip
|
<v-chip
|
||||||
v-bind="data.attrs"
|
v-bind="data.attrs"
|
||||||
|
@ -38,6 +52,8 @@
|
||||||
</v-list-item-content>
|
</v-list-item-content>
|
||||||
</template>
|
</template>
|
||||||
</v-autocomplete>
|
</v-autocomplete>
|
||||||
|
</div>
|
||||||
|
</v-expand-transition>
|
||||||
</v-card-text>
|
</v-card-text>
|
||||||
</v-card>
|
</v-card>
|
||||||
</div>
|
</div>
|
||||||
|
@ -45,22 +61,33 @@
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { mapGetters, mapActions } from 'vuex'
|
import { mapGetters, mapActions } from 'vuex'
|
||||||
|
import {mdiAccountPlus} from '@mdi/js'
|
||||||
export default {
|
export default {
|
||||||
name: 'Day',
|
name: 'Day',
|
||||||
props: {
|
props: {
|
||||||
day: Object
|
day: Object
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {}
|
return {
|
||||||
|
account_add: mdiAccountPlus,
|
||||||
|
searchInput: null,
|
||||||
|
focused: false
|
||||||
|
}
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
this.getUser({date: this.day.date.getTime()/1000})
|
this.setLoading(this.day.date)
|
||||||
|
this.getUser({
|
||||||
|
date: this.day.date.getTime() / 1000,
|
||||||
|
startdatetime: this.day.date
|
||||||
|
})
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
...mapActions({
|
...mapActions({
|
||||||
addUser: 'sm/addUser',
|
addUser: 'sm/addUser',
|
||||||
getUser: 'sm/getUser',
|
getUser: 'sm/getUser',
|
||||||
deleteUser: 'sm/deleteUser'
|
deleteUser: 'sm/deleteUser',
|
||||||
|
setLoading: 'sm/setDayLoading',
|
||||||
|
setNotLoading: 'sm/setDayNotLoading'
|
||||||
}),
|
}),
|
||||||
// eslint-disable-next-line no-unused-vars
|
// eslint-disable-next-line no-unused-vars
|
||||||
remove(deletedUser) {
|
remove(deletedUser) {
|
||||||
|
@ -69,7 +96,14 @@ export default {
|
||||||
})
|
})
|
||||||
const index = this.day.worker.indexOf(obj)
|
const index = this.day.worker.indexOf(obj)
|
||||||
if (index >= 0) this.day.worker.splice(index, 1)
|
if (index >= 0) this.day.worker.splice(index, 1)
|
||||||
this.deleteUser({startdatetime: this.day.date, date: this.day.date.getTime()/1000, user: deletedUser})
|
this.deleteUser({
|
||||||
|
startdatetime: this.day.date,
|
||||||
|
date: this.day.date.getTime() / 1000,
|
||||||
|
user: deletedUser
|
||||||
|
})
|
||||||
|
},
|
||||||
|
test(event) {
|
||||||
|
console.log('blur', event)
|
||||||
},
|
},
|
||||||
color: day => {
|
color: day => {
|
||||||
if (day) {
|
if (day) {
|
||||||
|
@ -85,11 +119,12 @@ export default {
|
||||||
} else {
|
} else {
|
||||||
return 'grey lighten-4'
|
return 'grey lighten-4'
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
...mapGetters({
|
...mapGetters({
|
||||||
allUsers: 'sm/allUsers'
|
allUsers: 'sm/allUsers',
|
||||||
|
disabled: 'sm/disabled'
|
||||||
}),
|
}),
|
||||||
worker() {
|
worker() {
|
||||||
return this.day.worker
|
return this.day.worker
|
||||||
|
@ -97,22 +132,39 @@ export default {
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
worker(newValue, oldValue) {
|
worker(newValue, oldValue) {
|
||||||
if (oldValue !== newValue) {
|
if (oldValue !== newValue && this.focused) {
|
||||||
let addedUser = null
|
let addedUser = null
|
||||||
for (let user in newValue) {
|
for (let user in newValue) {
|
||||||
if (!oldValue.includes(newValue[user])) {
|
if (!oldValue.includes(newValue[user])) {
|
||||||
addedUser = newValue[user]
|
addedUser = newValue[user]
|
||||||
this.addUser({date: this.day.date.getTime()/1000, user: addedUser})
|
this.addUser({
|
||||||
|
date: this.day.date.getTime() / 1000,
|
||||||
|
user: addedUser
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
let deletedUser = null
|
let deletedUser = null
|
||||||
for (let user in oldValue) {
|
for (let user in oldValue) {
|
||||||
if (!newValue.includes(oldValue[user])) {
|
if (!newValue.includes(oldValue[user])) {
|
||||||
deletedUser = oldValue[user]
|
deletedUser = oldValue[user]
|
||||||
this.deleteUser({startdatetime: this.day.date, date: this.day.date.getTime()/1000, user: deletedUser})
|
console.log("deleteUser", deletedUser, this.day.date)
|
||||||
|
this.deleteUser({
|
||||||
|
startdatetime: this.day.date,
|
||||||
|
date: this.day.date.getTime() / 1000,
|
||||||
|
user: deletedUser
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
day() {
|
||||||
|
this.getUser({
|
||||||
|
date: this.day.date.getTime() / 1000,
|
||||||
|
startdatetime: this.day.date
|
||||||
|
})
|
||||||
|
},
|
||||||
|
focused(newVal, oldValue) {
|
||||||
|
console.log(newVal, oldValue)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
//const main = 'https://192.168.5.128:5000/'
|
//const main = 'https://192.168.5.128:5000/'
|
||||||
const main = 'https://localhost:5000/'
|
const main = 'http://localhost:5000/'
|
||||||
|
//const main = 'http://192.168.5.118:5000/'
|
||||||
//const main = 'https://groeger-clan.duckdns.org:5000/'
|
//const main = 'https://groeger-clan.duckdns.org:5000/'
|
||||||
|
|
||||||
const url = {
|
const url = {
|
||||||
|
@ -25,6 +26,10 @@ const url = {
|
||||||
deleteUser: main + 'sm/deleteUser',
|
deleteUser: main + 'sm/deleteUser',
|
||||||
getUser: main + 'sm/getUser'
|
getUser: main + 'sm/getUser'
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
user: {
|
||||||
|
config: main + 'user/saveConfig',
|
||||||
|
job: main + 'user/job'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,10 @@
|
||||||
import Vue from 'vue'
|
import Vue from 'vue'
|
||||||
import Vuetify from 'vuetify/lib'
|
import Vuetify from 'vuetify/lib'
|
||||||
import 'material-design-icons-iconfont'
|
|
||||||
|
|
||||||
Vue.use(Vuetify)
|
Vue.use(Vuetify)
|
||||||
|
|
||||||
export default new Vuetify({
|
export default new Vuetify({
|
||||||
icons: {
|
icons: {
|
||||||
iconfont: 'md'
|
iconfont: 'mdiSvg'
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
|
@ -15,6 +15,8 @@ import FinanzerNavigation from '../components/finanzer/FinanzerNavigation'
|
||||||
import Overview from '../components/finanzer/Overview'
|
import Overview from '../components/finanzer/Overview'
|
||||||
import User from '../components/finanzer/User'
|
import User from '../components/finanzer/User'
|
||||||
import ServiceManagement from '../components/vorstand/ServiceManagement'
|
import ServiceManagement from '../components/vorstand/ServiceManagement'
|
||||||
|
import Config from "@/components/user/Config";
|
||||||
|
import Jobs from "@/components/user/Jobs";
|
||||||
|
|
||||||
Vue.use(VueRouter)
|
Vue.use(VueRouter)
|
||||||
|
|
||||||
|
@ -43,6 +45,16 @@ const routes = [
|
||||||
path: 'overview',
|
path: 'overview',
|
||||||
name: 'userOverview',
|
name: 'userOverview',
|
||||||
component: CreditOverview
|
component: CreditOverview
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'config',
|
||||||
|
name: 'userConfig',
|
||||||
|
component: Config
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'jobs',
|
||||||
|
name: 'userJobs',
|
||||||
|
component: Jobs
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -97,7 +109,6 @@ const router = new VueRouter({
|
||||||
|
|
||||||
router.beforeEach((to, from, next) => {
|
router.beforeEach((to, from, next) => {
|
||||||
store.dispatch('fetchAccessToken')
|
store.dispatch('fetchAccessToken')
|
||||||
console.log('fullPath', to.fullPath)
|
|
||||||
if (to.fullPath.includes('/main')) {
|
if (to.fullPath.includes('/main')) {
|
||||||
if (to.fullPath.includes('/main/finanzer')) {
|
if (to.fullPath.includes('/main/finanzer')) {
|
||||||
if (!store.state.login.user.group.includes('moneymaster')) {
|
if (!store.state.login.user.group.includes('moneymaster')) {
|
||||||
|
|
|
@ -4,7 +4,9 @@ import url from '@/plugins/routes'
|
||||||
const state = {
|
const state = {
|
||||||
users: [],
|
users: [],
|
||||||
allUsers: [],
|
allUsers: [],
|
||||||
filter: ''
|
filter: '',
|
||||||
|
usersLoading: false,
|
||||||
|
allUsersLoading: false
|
||||||
}
|
}
|
||||||
|
|
||||||
const mutations = {
|
const mutations = {
|
||||||
|
@ -36,12 +38,21 @@ const mutations = {
|
||||||
lastname: users[user].lastname,
|
lastname: users[user].lastname,
|
||||||
locked: users[user].locked,
|
locked: users[user].locked,
|
||||||
amount: users[user].amount,
|
amount: users[user].amount,
|
||||||
type: users[user].type
|
type: users[user].type,
|
||||||
|
loading: false
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
mutations.sortUsers(state)
|
mutations.sortUsers(state)
|
||||||
},
|
},
|
||||||
|
updateUser: (state, data) => {
|
||||||
|
let index = state.users.indexOf(
|
||||||
|
state.users.find(a => {
|
||||||
|
return a.username === data.username
|
||||||
|
})
|
||||||
|
)
|
||||||
|
if (data.loading !== undefined) state.users[index].loading = data.loading
|
||||||
|
},
|
||||||
sortUsers: state => {
|
sortUsers: state => {
|
||||||
state.users = state.users.sort((a, b) => {
|
state.users = state.users.sort((a, b) => {
|
||||||
if (a.lastname > b.lastname) return 1
|
if (a.lastname > b.lastname) return 1
|
||||||
|
@ -53,12 +64,19 @@ const mutations = {
|
||||||
},
|
},
|
||||||
setFilter: (state, filter) => {
|
setFilter: (state, filter) => {
|
||||||
state.filter = filter
|
state.filter = filter
|
||||||
|
},
|
||||||
|
setUsersLoading: (state, value) => {
|
||||||
|
state.usersLoading = value
|
||||||
|
},
|
||||||
|
setAllUsersLoading: (state, value) => {
|
||||||
|
state.allUsersLoading = value
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const actions = {
|
const actions = {
|
||||||
// eslint-disable-next-line no-unused-vars
|
// eslint-disable-next-line no-unused-vars
|
||||||
async getUsers({ commit, rootState, dispatch }) {
|
async getUsers({ commit, rootState, dispatch }) {
|
||||||
|
commit('setUsersLoading', true)
|
||||||
try {
|
try {
|
||||||
const response = await axios.get(url.bar, {
|
const response = await axios.get(url.bar, {
|
||||||
headers: { Token: rootState.login.user.accessToken }
|
headers: { Token: rootState.login.user.accessToken }
|
||||||
|
@ -68,8 +86,10 @@ const actions = {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('setUsersLoading', false)
|
||||||
},
|
},
|
||||||
async addAmount({ commit, rootState, dispatch }, data) {
|
async addAmount({ commit, rootState, dispatch }, data) {
|
||||||
|
commit('updateUser', { username: data.username, loading: true })
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(
|
const response = await axios.post(
|
||||||
url.barAddAmount,
|
url.barAddAmount,
|
||||||
|
@ -81,8 +101,10 @@ const actions = {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('updateUser', { username: data.username, loading: false })
|
||||||
},
|
},
|
||||||
async addCreditList({ commit, rootState, dispatch }, data) {
|
async addCreditList({ commit, rootState, dispatch }, data) {
|
||||||
|
commit('updateUser', { username: data.username, loading: true })
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(
|
const response = await axios.post(
|
||||||
url.barGetUser,
|
url.barGetUser,
|
||||||
|
@ -94,8 +116,10 @@ const actions = {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('updateUser', { username: data.username, loading: false })
|
||||||
},
|
},
|
||||||
async getAllUsers({ commit, rootState, dispatch }) {
|
async getAllUsers({ commit, rootState, dispatch }) {
|
||||||
|
commit('setAllUsersLoading', true)
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(
|
const response = await axios.post(
|
||||||
url.searchUser,
|
url.searchUser,
|
||||||
|
@ -107,6 +131,7 @@ const actions = {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.data === 401) dispatch('logout', null, { root: true })
|
if (e.response.data === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('setAllUsersLoading', false)
|
||||||
},
|
},
|
||||||
setFilter({ commit }, data) {
|
setFilter({ commit }, data) {
|
||||||
commit('setFilter', data)
|
commit('setFilter', data)
|
||||||
|
@ -122,6 +147,12 @@ const getters = {
|
||||||
},
|
},
|
||||||
filter: state => {
|
filter: state => {
|
||||||
return state.filter
|
return state.filter
|
||||||
|
},
|
||||||
|
usersLoading: state => {
|
||||||
|
return state.usersLoading
|
||||||
|
},
|
||||||
|
allUsersLoading: state => {
|
||||||
|
return state.allUsersLoading
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,11 @@ const state = {
|
||||||
{ value: 10, text: 'Oktober' },
|
{ value: 10, text: 'Oktober' },
|
||||||
{ value: 11, text: 'November' },
|
{ value: 11, text: 'November' },
|
||||||
{ value: 12, text: 'Dezember' }
|
{ value: 12, text: 'Dezember' }
|
||||||
]
|
],
|
||||||
|
allUsersLoading: false,
|
||||||
|
usersLoading: false,
|
||||||
|
emailLoading: false,
|
||||||
|
addUserLoading: false
|
||||||
}
|
}
|
||||||
|
|
||||||
const mutations = {
|
const mutations = {
|
||||||
|
@ -73,7 +77,8 @@ const mutations = {
|
||||||
locked: users[user].locked,
|
locked: users[user].locked,
|
||||||
autoLock: users[user].autoLock,
|
autoLock: users[user].autoLock,
|
||||||
creditList: list,
|
creditList: list,
|
||||||
expand: false
|
expand: false,
|
||||||
|
loading: false
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -202,6 +207,7 @@ const mutations = {
|
||||||
if (data.locked !== undefined) state.users[index].locked = data.locked
|
if (data.locked !== undefined) state.users[index].locked = data.locked
|
||||||
if (data.limit !== undefined) state.users[index].limit = data.limit
|
if (data.limit !== undefined) state.users[index].limit = data.limit
|
||||||
if (data.autoLock !== undefined) state.users[index].autoLock = data.autoLock
|
if (data.autoLock !== undefined) state.users[index].autoLock = data.autoLock
|
||||||
|
if (data.loading !== undefined) state.users[index].loading = data.loading
|
||||||
},
|
},
|
||||||
setMails: (state, data) => {
|
setMails: (state, data) => {
|
||||||
state.errorMails = data
|
state.errorMails = data
|
||||||
|
@ -217,12 +223,25 @@ const mutations = {
|
||||||
setYear: (state, value) => {
|
setYear: (state, value) => {
|
||||||
if (value) state.year++
|
if (value) state.year++
|
||||||
else state.year--
|
else state.year--
|
||||||
|
},
|
||||||
|
setAllUsersLoading: (state, value) => {
|
||||||
|
state.allUsersLoading = value
|
||||||
|
},
|
||||||
|
setUsersLoading: (state, value) => {
|
||||||
|
state.usersLoading = value
|
||||||
|
},
|
||||||
|
setEMailLoading: (state, value) => {
|
||||||
|
state.emailLoading = value
|
||||||
|
},
|
||||||
|
setAddUserLoading: (state, value) => {
|
||||||
|
state.addUserLoading = value
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const actions = {
|
const actions = {
|
||||||
// eslint-disable-next-line no-unused-vars
|
// eslint-disable-next-line no-unused-vars
|
||||||
async getAllUsers({ commit, rootState, dispatch }) {
|
async getAllUsers({ commit, rootState, dispatch }) {
|
||||||
|
commit('setAllUsersLoading', true)
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(
|
const response = await axios.post(
|
||||||
url.searchUser,
|
url.searchUser,
|
||||||
|
@ -236,8 +255,10 @@ const actions = {
|
||||||
if (err.response.status === 401)
|
if (err.response.status === 401)
|
||||||
dispatch('logout', null, { root: true })
|
dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('setAllUsersLoading', false)
|
||||||
},
|
},
|
||||||
async getUsers({ commit, rootState, dispatch }) {
|
async getUsers({ commit, rootState, dispatch }) {
|
||||||
|
commit('setUsersLoading', true)
|
||||||
try {
|
try {
|
||||||
const response = await axios.get(url.getFinanzerMain, {
|
const response = await axios.get(url.getFinanzerMain, {
|
||||||
headers: { Token: rootState.login.user.accessToken }
|
headers: { Token: rootState.login.user.accessToken }
|
||||||
|
@ -248,11 +269,13 @@ const actions = {
|
||||||
if (err.response.status === 401)
|
if (err.response.status === 401)
|
||||||
dispatch('logout', null, { root: true })
|
dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('setUsersLoading', false)
|
||||||
},
|
},
|
||||||
setActiveUser({ commit }, username) {
|
setActiveUser({ commit }, username) {
|
||||||
commit('setActiveUser', username)
|
commit('setActiveUser', username)
|
||||||
},
|
},
|
||||||
async addAmount({ commit, rootState, dispatch }, data) {
|
async addAmount({ commit, rootState, dispatch }, data) {
|
||||||
|
commit('updateUsers', { username: data.user.username, loading: true })
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(
|
const response = await axios.post(
|
||||||
url.finanzerAddAmount,
|
url.finanzerAddAmount,
|
||||||
|
@ -276,8 +299,10 @@ const actions = {
|
||||||
if (err.response.status === 401)
|
if (err.response.status === 401)
|
||||||
dispatch('logout', null, { root: true })
|
dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('updateUsers', { username: data.user.username, loading: false })
|
||||||
},
|
},
|
||||||
async addCredit({ commit, rootState, dispatch }, data) {
|
async addCredit({ commit, rootState, dispatch }, data) {
|
||||||
|
commit('updateUsers', { username: data.user.username, loading: true })
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(
|
const response = await axios.post(
|
||||||
url.finanzerAddCredit,
|
url.finanzerAddCredit,
|
||||||
|
@ -301,8 +326,10 @@ const actions = {
|
||||||
if (err.response.status === 401)
|
if (err.response.status === 401)
|
||||||
dispatch('logout', null, { root: true })
|
dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('updateUsers', { username: data.user.username, loading: false })
|
||||||
},
|
},
|
||||||
async doLock({ commit, rootState, dispatch }, data) {
|
async doLock({ commit, rootState, dispatch }, data) {
|
||||||
|
commit('updateUsers', { username: data.user.username, loading: true })
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(
|
const response = await axios.post(
|
||||||
url.lockUser,
|
url.lockUser,
|
||||||
|
@ -314,8 +341,10 @@ const actions = {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('updateUsers', { username: data.user.username, loading: false })
|
||||||
},
|
},
|
||||||
async saveConfig({ commit, rootState, dispatch }, data) {
|
async saveConfig({ commit, rootState, dispatch }, data) {
|
||||||
|
commit('updateUsers', { username: data.user.username, loading: true })
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(
|
const response = await axios.post(
|
||||||
url.finanzerSetConfig,
|
url.finanzerSetConfig,
|
||||||
|
@ -331,8 +360,10 @@ const actions = {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('updateUsers', { username: data.user.username, loading: false })
|
||||||
},
|
},
|
||||||
async addUser({ commit, rootState, dispatch }, data) {
|
async addUser({ commit, rootState, dispatch }, data) {
|
||||||
|
commit('setAddUserLoading', true)
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(
|
const response = await axios.post(
|
||||||
url.finanzerAddUser,
|
url.finanzerAddUser,
|
||||||
|
@ -344,8 +375,10 @@ const actions = {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('setAddUserLoading', false)
|
||||||
},
|
},
|
||||||
async sendMails({ commit, rootState, dispatch }) {
|
async sendMails({ commit, rootState, dispatch }) {
|
||||||
|
commit('setEMailLoading', true)
|
||||||
try {
|
try {
|
||||||
const response = await axios.get(url.finanzerSendAllMail, {
|
const response = await axios.get(url.finanzerSendAllMail, {
|
||||||
headers: { Token: rootState.login.user.accessToken }
|
headers: { Token: rootState.login.user.accessToken }
|
||||||
|
@ -355,8 +388,10 @@ const actions = {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('setEMailLoading', false)
|
||||||
},
|
},
|
||||||
async sendMail({ commit, rootState, dispatch }, data) {
|
async sendMail({ commit, rootState, dispatch }, data) {
|
||||||
|
commit('updateUsers', { username: data.username, loading: true })
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(
|
const response = await axios.post(
|
||||||
url.finanzerSendOneMail,
|
url.finanzerSendOneMail,
|
||||||
|
@ -368,6 +403,7 @@ const actions = {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('updateUsers', { username: data.username, loading: false })
|
||||||
},
|
},
|
||||||
createYears({ commit }) {
|
createYears({ commit }) {
|
||||||
commit('setYears')
|
commit('setYears')
|
||||||
|
@ -410,6 +446,15 @@ const getters = {
|
||||||
},
|
},
|
||||||
months: state => {
|
months: state => {
|
||||||
return state.months
|
return state.months
|
||||||
|
},
|
||||||
|
allUsersLoading: state => {
|
||||||
|
return state.allUsersLoading
|
||||||
|
},
|
||||||
|
usersLoading: state => {
|
||||||
|
return state.usersLoading
|
||||||
|
},
|
||||||
|
addUserLoading: state => {
|
||||||
|
return state.addUserLoading
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,8 @@ import url from '@/plugins/routes'
|
||||||
const state = {
|
const state = {
|
||||||
user: {
|
user: {
|
||||||
username: null,
|
username: null,
|
||||||
|
firstname: null,
|
||||||
|
lastname: null,
|
||||||
accessToken: null,
|
accessToken: null,
|
||||||
group: null
|
group: null
|
||||||
},
|
},
|
||||||
|
@ -30,12 +32,16 @@ const mutations = {
|
||||||
state.user.username = data.username
|
state.user.username = data.username
|
||||||
state.user.accessToken = data.accessToken
|
state.user.accessToken = data.accessToken
|
||||||
state.user.group = data.group
|
state.user.group = data.group
|
||||||
|
state.user.firstname = data.firstname
|
||||||
|
state.user.lastname = data.lastname
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
logout(state) {
|
logout(state) {
|
||||||
state.user.accessToken = null
|
state.user.accessToken = null
|
||||||
state.user.username = null
|
state.user.username = null
|
||||||
state.user.group = null
|
state.user.group = null
|
||||||
|
state.user.firstname = null
|
||||||
|
state.user.lastname = null
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,12 +50,15 @@ const actions = {
|
||||||
commit('loginStart')
|
commit('loginStart')
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(url.login, { ...loginData })
|
const response = await axios.post(url.login, { ...loginData })
|
||||||
|
console.log(response.data)
|
||||||
localStorage.setItem(
|
localStorage.setItem(
|
||||||
'user',
|
'user',
|
||||||
JSON.stringify({
|
JSON.stringify({
|
||||||
username: response.data.username,
|
username: response.data.username,
|
||||||
accessToken: response.data.token,
|
accessToken: response.data.token,
|
||||||
group: response.data.group
|
group: response.data.group,
|
||||||
|
firstname: response.data.firstname,
|
||||||
|
lastname: response.data.lastname
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
commit('loginStop', null)
|
commit('loginStop', null)
|
||||||
|
@ -66,7 +75,9 @@ const actions = {
|
||||||
commit('updateAccessToken', {
|
commit('updateAccessToken', {
|
||||||
username: null,
|
username: null,
|
||||||
accessToken: null,
|
accessToken: null,
|
||||||
group: null
|
group: null,
|
||||||
|
firstname: null,
|
||||||
|
lastname: null
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -84,6 +95,9 @@ const actions = {
|
||||||
}
|
}
|
||||||
|
|
||||||
const getters = {
|
const getters = {
|
||||||
|
loggingIn: state => {
|
||||||
|
return state.loggingIn
|
||||||
|
},
|
||||||
getGroup: state => {
|
getGroup: state => {
|
||||||
return state.user.group
|
return state.user.group
|
||||||
},
|
},
|
||||||
|
@ -122,6 +136,9 @@ const getters = {
|
||||||
},
|
},
|
||||||
isLoggedIn: state => {
|
isLoggedIn: state => {
|
||||||
return state.user.accessToken ? true : false
|
return state.user.accessToken ? true : false
|
||||||
|
},
|
||||||
|
user: state => {
|
||||||
|
return state.user
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,8 @@ import url from '@/plugins/routes'
|
||||||
|
|
||||||
const state = {
|
const state = {
|
||||||
month: [],
|
month: [],
|
||||||
allUsers: []
|
allUsers: [],
|
||||||
|
disabled: false
|
||||||
}
|
}
|
||||||
|
|
||||||
const mutations = {
|
const mutations = {
|
||||||
|
@ -45,7 +46,8 @@ const mutations = {
|
||||||
id: currentDate.getDay(),
|
id: currentDate.getDay(),
|
||||||
date: currentDate,
|
date: currentDate,
|
||||||
name: 'Montag',
|
name: 'Montag',
|
||||||
worker: []
|
worker: [],
|
||||||
|
loading: false
|
||||||
}
|
}
|
||||||
break
|
break
|
||||||
case 2:
|
case 2:
|
||||||
|
@ -53,7 +55,8 @@ const mutations = {
|
||||||
id: currentDate.getDay(),
|
id: currentDate.getDay(),
|
||||||
date: currentDate,
|
date: currentDate,
|
||||||
name: 'Dienstag',
|
name: 'Dienstag',
|
||||||
worker: []
|
worker: [],
|
||||||
|
loading: false
|
||||||
}
|
}
|
||||||
break
|
break
|
||||||
case 3:
|
case 3:
|
||||||
|
@ -66,7 +69,8 @@ const mutations = {
|
||||||
id: currentDate.getDay(),
|
id: currentDate.getDay(),
|
||||||
date: currentDate,
|
date: currentDate,
|
||||||
name: 'Mittwoch',
|
name: 'Mittwoch',
|
||||||
worker: []
|
worker: [],
|
||||||
|
loading: false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break
|
break
|
||||||
|
@ -75,7 +79,8 @@ const mutations = {
|
||||||
id: currentDate.getDay(),
|
id: currentDate.getDay(),
|
||||||
date: currentDate,
|
date: currentDate,
|
||||||
name: 'Donnerstag',
|
name: 'Donnerstag',
|
||||||
worker: []
|
worker: [],
|
||||||
|
loading: false
|
||||||
}
|
}
|
||||||
break
|
break
|
||||||
case 5:
|
case 5:
|
||||||
|
@ -83,7 +88,8 @@ const mutations = {
|
||||||
id: currentDate.getDay(),
|
id: currentDate.getDay(),
|
||||||
date: currentDate,
|
date: currentDate,
|
||||||
name: 'Freitag',
|
name: 'Freitag',
|
||||||
worker: []
|
worker: [],
|
||||||
|
loading: false
|
||||||
}
|
}
|
||||||
break
|
break
|
||||||
case 6:
|
case 6:
|
||||||
|
@ -91,7 +97,8 @@ const mutations = {
|
||||||
id: currentDate.getDay(),
|
id: currentDate.getDay(),
|
||||||
date: currentDate,
|
date: currentDate,
|
||||||
name: 'Samstag',
|
name: 'Samstag',
|
||||||
worker: []
|
worker: [],
|
||||||
|
loading: false
|
||||||
}
|
}
|
||||||
break
|
break
|
||||||
case 0:
|
case 0:
|
||||||
|
@ -99,7 +106,8 @@ const mutations = {
|
||||||
id: currentDate.getDay(),
|
id: currentDate.getDay(),
|
||||||
date: currentDate,
|
date: currentDate,
|
||||||
name: 'Sontag',
|
name: 'Sontag',
|
||||||
worker: []
|
worker: [],
|
||||||
|
loading: false
|
||||||
}
|
}
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
@ -159,11 +167,24 @@ const mutations = {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
setDayLoading: (state, { date, getters }) => {
|
||||||
|
let day = getters.getDay(date)
|
||||||
|
day.loading = true
|
||||||
|
},
|
||||||
|
setDayNotLoading: (state, { date, getters }) => {
|
||||||
|
let day = getters.getDay(date)
|
||||||
|
day.loading = false
|
||||||
|
},
|
||||||
|
setDisabled: (state, data) => {
|
||||||
|
state.disabled = data
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
const actions = {
|
const actions = {
|
||||||
createMonth({ commit }, date) {
|
createMonth({ commit }, date) {
|
||||||
|
commit('setDisabled', true)
|
||||||
commit('createMonth', date)
|
commit('createMonth', date)
|
||||||
|
commit('setDisabled', false)
|
||||||
},
|
},
|
||||||
async getAllUsers({ commit, rootState, dispatch }) {
|
async getAllUsers({ commit, rootState, dispatch }) {
|
||||||
try {
|
try {
|
||||||
|
@ -188,14 +209,14 @@ const actions = {
|
||||||
headers: { Token: rootState.login.user.accessToken }
|
headers: { Token: rootState.login.user.accessToken }
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
console.log(response.data)
|
commit('updateMonth', { ...response.data[0], com: 'add' })
|
||||||
commit('updateMonth', {...response.data[0], com: 'add'})
|
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
async getUser({ commit, rootState, dispatch }, data) {
|
async getUser({ commit, rootState, dispatch, getters }, data) {
|
||||||
|
commit('setDayLoading', { date: data.startdatetime, getters })
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(
|
const response = await axios.post(
|
||||||
url.vorstand.sm.getUser,
|
url.vorstand.sm.getUser,
|
||||||
|
@ -205,6 +226,7 @@ const actions = {
|
||||||
for (let item = 0; item < response.data.length; item++) {
|
for (let item = 0; item < response.data.length; item++) {
|
||||||
commit('updateMonth', { ...response.data[item], com: 'add' })
|
commit('updateMonth', { ...response.data[item], com: 'add' })
|
||||||
}
|
}
|
||||||
|
commit('setDayNotLoading', { date: data.startdatetime, getters })
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
|
@ -219,11 +241,17 @@ const actions = {
|
||||||
{ ...data },
|
{ ...data },
|
||||||
{ headers: { Token: rootState.login.user.accessToken } }
|
{ headers: { Token: rootState.login.user.accessToken } }
|
||||||
)
|
)
|
||||||
commit('updateMonth', {...data, com: 'delete'})
|
commit('updateMonth', { ...data, com: 'delete' })
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
setDayLoading({ commit, getters }, date) {
|
||||||
|
commit('setDayLoading', { date, getters })
|
||||||
|
},
|
||||||
|
setDayNotLoading({ commit, getters }, date) {
|
||||||
|
commit('setDayNotLoading', { date, getters })
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
const getters = {
|
const getters = {
|
||||||
|
@ -232,6 +260,22 @@ const getters = {
|
||||||
},
|
},
|
||||||
allUsers: state => {
|
allUsers: state => {
|
||||||
return state.allUsers
|
return state.allUsers
|
||||||
|
},
|
||||||
|
getDayLoading: (state, getters) => date => {
|
||||||
|
let day = getters.getDay(date)
|
||||||
|
return day.loading
|
||||||
|
},
|
||||||
|
getDay: state => date => {
|
||||||
|
for (let week = 0; week < state.month.length; week++) {
|
||||||
|
for (let day in state.month[week].days) {
|
||||||
|
if (state.month[week].days[day].date - date === 0) {
|
||||||
|
return state.month[week].days[day]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
disabled: state => {
|
||||||
|
return state.disabled
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,11 @@ import url from '@/plugins/routes'
|
||||||
|
|
||||||
const state = {
|
const state = {
|
||||||
user: null,
|
user: null,
|
||||||
creditList: []
|
creditList: [],
|
||||||
|
loading: false,
|
||||||
|
addLoading: false,
|
||||||
|
error: '',
|
||||||
|
days: []
|
||||||
}
|
}
|
||||||
|
|
||||||
const mutations = {
|
const mutations = {
|
||||||
|
@ -11,6 +15,7 @@ const mutations = {
|
||||||
state.user = user
|
state.user = user
|
||||||
let list = {}
|
let list = {}
|
||||||
for (let creditList in user['creditList']) {
|
for (let creditList in user['creditList']) {
|
||||||
|
// eslint-disable-next-line no-console
|
||||||
console.log(creditList)
|
console.log(creditList)
|
||||||
let amount = mutations.createAmount(user['creditList'][creditList])
|
let amount = mutations.createAmount(user['creditList'][creditList])
|
||||||
let credit = mutations.createCredit(user['creditList'][creditList])
|
let credit = mutations.createCredit(user['creditList'][creditList])
|
||||||
|
@ -19,6 +24,8 @@ const mutations = {
|
||||||
}
|
}
|
||||||
state.user.creditList = list
|
state.user.creditList = list
|
||||||
state.creditList = []
|
state.creditList = []
|
||||||
|
state.error = ''
|
||||||
|
// eslint-disable-next-line no-console
|
||||||
console.log(state.user)
|
console.log(state.user)
|
||||||
},
|
},
|
||||||
createAmount(creditList) {
|
createAmount(creditList) {
|
||||||
|
@ -115,22 +122,61 @@ const mutations = {
|
||||||
sum.nov_amount +
|
sum.nov_amount +
|
||||||
sum.dez_amount
|
sum.dez_amount
|
||||||
return sum
|
return sum
|
||||||
|
},
|
||||||
|
setLoading(state, value) {
|
||||||
|
state.loading = value
|
||||||
|
},
|
||||||
|
setAddLoading(state, value) {
|
||||||
|
state.addLoading = value
|
||||||
|
},
|
||||||
|
setError(state, value) {
|
||||||
|
state.error = value
|
||||||
|
console.log(state)
|
||||||
|
},
|
||||||
|
createDays(state, date) {
|
||||||
|
let days = []
|
||||||
|
for (let i = 0; i <= 10; i++) {
|
||||||
|
days.push({
|
||||||
|
date: new Date(
|
||||||
|
date.getFullYear(),
|
||||||
|
date.getMonth(),
|
||||||
|
date.getDate() + i,
|
||||||
|
12
|
||||||
|
),
|
||||||
|
job: false,
|
||||||
|
workers: []
|
||||||
|
})
|
||||||
|
}
|
||||||
|
state.days = days
|
||||||
|
},
|
||||||
|
updateDay(state, data) {
|
||||||
|
const date = data.date
|
||||||
|
for (let day in state.days) {
|
||||||
|
if (state.days[day].date - date === 0) {
|
||||||
|
state.days[day].job = data.job
|
||||||
|
if (data.workers) state.days[day].workers = data.workers
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const actions = {
|
const actions = {
|
||||||
async getUser({ commit, rootState, dispatch }) {
|
async getUser({ commit, rootState, dispatch }) {
|
||||||
|
commit('setLoading', true)
|
||||||
try {
|
try {
|
||||||
const response = await axios.get(url.userMain, {
|
const response = await axios.get(url.userMain, {
|
||||||
headers: { Token: rootState.login.user.accessToken }
|
headers: { Token: rootState.login.user.accessToken }
|
||||||
})
|
})
|
||||||
commit('setUser', response.data)
|
commit('setUser', response.data)
|
||||||
|
commit('setError', '')
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('setLoading', false)
|
||||||
},
|
},
|
||||||
async addAmount({ commit, rootState, dispatch }, amount) {
|
async addAmount({ commit, rootState, dispatch }, amount) {
|
||||||
|
commit('setAddLoading', true)
|
||||||
try {
|
try {
|
||||||
const response = await axios.post(
|
const response = await axios.post(
|
||||||
url.userAddAmount,
|
url.userAddAmount,
|
||||||
|
@ -138,10 +184,60 @@ const actions = {
|
||||||
{ headers: { Token: rootState.login.user.accessToken } }
|
{ headers: { Token: rootState.login.user.accessToken } }
|
||||||
)
|
)
|
||||||
commit('setUser', response.data)
|
commit('setUser', response.data)
|
||||||
|
commit('setError', '')
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
if (e.response)
|
if (e.response)
|
||||||
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
}
|
}
|
||||||
|
commit('setAddLoading', false)
|
||||||
|
},
|
||||||
|
async saveConfig({ commit, rootState, dispatch }, data) {
|
||||||
|
commit('setLoading', true)
|
||||||
|
try {
|
||||||
|
const response = await axios.post(
|
||||||
|
url.user.config,
|
||||||
|
{ ...data },
|
||||||
|
{ headers: { Token: rootState.login.user.accessToken } }
|
||||||
|
)
|
||||||
|
console.log(response.data)
|
||||||
|
commit('setUser', response.data)
|
||||||
|
commit('setError', '')
|
||||||
|
} catch (e) {
|
||||||
|
if (e.response) {
|
||||||
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
|
if (e.response.data) {
|
||||||
|
console.log(e.response.data)
|
||||||
|
commit('setError', e.response.data.error)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
commit('setLoading', false)
|
||||||
|
},
|
||||||
|
createDays({ commit }, date) {
|
||||||
|
commit('createDays', date)
|
||||||
|
},
|
||||||
|
async updateDay({ commit, rootState, dispatch }, data) {
|
||||||
|
commit('setLoading', true)
|
||||||
|
try {
|
||||||
|
console.log('hier bin ich')
|
||||||
|
const response = await axios.post(
|
||||||
|
url.user.job,
|
||||||
|
{ date: data.date.getTime() / 1000 },
|
||||||
|
{ headers: { Token: rootState.login.user.accessToken } }
|
||||||
|
)
|
||||||
|
console.log(response.data)
|
||||||
|
commit('updateDay', { ...response.data, date: data.date })
|
||||||
|
} catch (e) {
|
||||||
|
if (e.response) {
|
||||||
|
if (e.response.status === 401) dispatch('logout', null, { root: true })
|
||||||
|
if (e.response.data) {
|
||||||
|
console.log(e.response.data, data.date)
|
||||||
|
commit('setError', e.response.data.error)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
console.log(e)
|
||||||
|
}
|
||||||
|
commit('setLoading', false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -156,6 +252,18 @@ const getters = {
|
||||||
if (currentYear > year) year = currentYear
|
if (currentYear > year) year = currentYear
|
||||||
}
|
}
|
||||||
return year
|
return year
|
||||||
|
},
|
||||||
|
loading: state => {
|
||||||
|
return state.loading
|
||||||
|
},
|
||||||
|
addLoading: state => {
|
||||||
|
return state.addLoading
|
||||||
|
},
|
||||||
|
error: state => {
|
||||||
|
return state.error
|
||||||
|
},
|
||||||
|
days: state => {
|
||||||
|
return state.days
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -14,7 +14,6 @@
|
||||||
<v-text-field
|
<v-text-field
|
||||||
label="Login"
|
label="Login"
|
||||||
name="login"
|
name="login"
|
||||||
prepend-icon="person"
|
|
||||||
type="text"
|
type="text"
|
||||||
v-model="username"
|
v-model="username"
|
||||||
ref="first"
|
ref="first"
|
||||||
|
@ -22,21 +21,31 @@
|
||||||
doLogin({ username: username, password: password })
|
doLogin({ username: username, password: password })
|
||||||
"
|
"
|
||||||
@input="resetLoginError"
|
@input="resetLoginError"
|
||||||
/>
|
>
|
||||||
|
<template v-slot:prepend-inner>
|
||||||
|
<v-icon>{{account}}</v-icon>
|
||||||
|
</template>
|
||||||
|
</v-text-field>
|
||||||
|
|
||||||
<v-text-field
|
<v-text-field
|
||||||
id="password"
|
id="password"
|
||||||
label="Password"
|
label="Password"
|
||||||
name="password"
|
name="password"
|
||||||
prepend-icon="lock"
|
|
||||||
type="password"
|
type="password"
|
||||||
v-model="password"
|
v-model="password"
|
||||||
@keyup.enter="
|
@keyup.enter="
|
||||||
doLogin({ username: username, password: password })
|
doLogin({ username: username, password: password })
|
||||||
"
|
"
|
||||||
@input="resetLoginError"
|
@input="resetLoginError"
|
||||||
/>
|
>
|
||||||
|
<template v-slot:prepend-inner>
|
||||||
|
<v-icon>{{lock}}</v-icon>
|
||||||
|
</template>
|
||||||
|
</v-text-field>
|
||||||
</v-form>
|
</v-form>
|
||||||
|
<div class="text-center">
|
||||||
|
<v-progress-circular indeterminate v-if="loggingIn" />
|
||||||
|
</div>
|
||||||
</v-card-text>
|
</v-card-text>
|
||||||
<v-alert v-if="loginError" dense type="error">{{
|
<v-alert v-if="loginError" dense type="error">{{
|
||||||
loginError
|
loginError
|
||||||
|
@ -62,19 +71,21 @@
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
// eslint-disable-next-line no-unused-vars
|
// eslint-disable-next-line no-unused-vars
|
||||||
import { mapActions } from 'vuex'
|
import { mapActions, mapGetters } from 'vuex'
|
||||||
import { mapGetters } from 'vuex'
|
import { mdiAccount, mdiLock } from '@mdi/js'
|
||||||
export default {
|
export default {
|
||||||
name: 'Login',
|
name: 'Login',
|
||||||
components: {},
|
components: {},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
username: null,
|
username: null,
|
||||||
password: null
|
password: null,
|
||||||
|
account: mdiAccount,
|
||||||
|
lock: mdiLock
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: mapActions(['doLogin', 'resetLoginError']),
|
methods: mapActions(['doLogin', 'resetLoginError']),
|
||||||
computed: mapGetters(['loginError'])
|
computed: mapGetters(['loginError', 'loggingIn'])
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
|
@ -12,21 +12,21 @@
|
||||||
<v-list>
|
<v-list>
|
||||||
<v-list-item v-if="isUser" class="title" link to="/main/user/add">
|
<v-list-item v-if="isUser" class="title" link to="/main/user/add">
|
||||||
<v-list-item-icon>
|
<v-list-item-icon>
|
||||||
<v-icon>person</v-icon>
|
<v-icon>{{person}}</v-icon>
|
||||||
</v-list-item-icon>
|
</v-list-item-icon>
|
||||||
<v-list-item-title>Account</v-list-item-title>
|
<v-list-item-title>{{user.firstname}} {{user.lastname}}</v-list-item-title>
|
||||||
</v-list-item>
|
</v-list-item>
|
||||||
<v-list-item v-if="isBar" class="title" link to="/main/bar/geruecht">
|
<v-list-item v-if="isBar" class="title" link to="/main/bar/geruecht">
|
||||||
<v-list-item-icon>
|
<v-list-item-icon>
|
||||||
<v-icon>local_bar</v-icon>
|
<v-icon>{{glass_cocktail}}</v-icon>
|
||||||
</v-list-item-icon>
|
</v-list-item-icon>
|
||||||
<v-list-item-title>
|
<v-list-item-title>
|
||||||
Gerüchte
|
Bar
|
||||||
</v-list-item-title>
|
</v-list-item-title>
|
||||||
</v-list-item>
|
</v-list-item>
|
||||||
<v-list-item v-if="isFinanzer" class="title" link to="/main/finanzer/overview">
|
<v-list-item v-if="isFinanzer" class="title" link to="/main/finanzer/overview">
|
||||||
<v-list-item-icon>
|
<v-list-item-icon>
|
||||||
<v-icon>attach_money</v-icon>
|
<v-icon>{{attach_money}}</v-icon>
|
||||||
</v-list-item-icon>
|
</v-list-item-icon>
|
||||||
<v-list-item-title>Finanzer</v-list-item-title>
|
<v-list-item-title>Finanzer</v-list-item-title>
|
||||||
</v-list-item>
|
</v-list-item>
|
||||||
|
@ -39,7 +39,7 @@
|
||||||
<v-list>
|
<v-list>
|
||||||
<v-list-item>
|
<v-list-item>
|
||||||
<v-list-item-icon>
|
<v-list-item-icon>
|
||||||
<v-icon>exit_to_app</v-icon>
|
<v-icon>{{exit_to_app}}</v-icon>
|
||||||
</v-list-item-icon>
|
</v-list-item-icon>
|
||||||
<v-list-item-title>
|
<v-list-item-title>
|
||||||
<v-btn block text @click="logout">Logout</v-btn>
|
<v-btn block text @click="logout">Logout</v-btn>
|
||||||
|
@ -54,8 +54,17 @@
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { mapActions, mapGetters } from 'vuex'
|
import { mapActions, mapGetters } from 'vuex'
|
||||||
|
import {mdiAccount, mdiCurrencyEur, mdiExitToApp, mdiGlassCocktail} from '@mdi/js'
|
||||||
export default {
|
export default {
|
||||||
name: 'MainView',
|
name: 'MainView',
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
person: mdiAccount,
|
||||||
|
attach_money: mdiCurrencyEur,
|
||||||
|
exit_to_app: mdiExitToApp,
|
||||||
|
glass_cocktail: mdiGlassCocktail
|
||||||
|
}
|
||||||
|
},
|
||||||
components: { },
|
components: { },
|
||||||
created() {
|
created() {
|
||||||
},
|
},
|
||||||
|
@ -70,7 +79,8 @@ export default {
|
||||||
isBar: 'isBar',
|
isBar: 'isBar',
|
||||||
isUser: 'isUser',
|
isUser: 'isUser',
|
||||||
isFinanzer: 'isFinanzer',
|
isFinanzer: 'isFinanzer',
|
||||||
isLoggedIn: 'isLoggedIn'
|
isLoggedIn: 'isLoggedIn',
|
||||||
|
user: 'user'
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue