{
for(let concert of concertStore.concerts) {
@@ -112,7 +115,7 @@ concertStore.getConcerts()
icon="mdi-account"
>
- {{ bandStore.availableGenres.length }} {{ $t('band.genre', 2) }}
+ {{ genreStore.genres.length }} {{ $t('band.genre', 2) }}
diff --git a/software/src/pages/admin/genresAdminPage/genreEditDialog.vue b/software/src/pages/admin/genresAdminPage/genreEditDialog.vue
new file mode 100644
index 0000000..7df2c62
--- /dev/null
+++ b/software/src/pages/admin/genresAdminPage/genreEditDialog.vue
@@ -0,0 +1,38 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {{ $t('misc.actions.save') }}
+
+
+
+
\ No newline at end of file
diff --git a/software/src/pages/admin/genresAdminPage/index.vue b/software/src/pages/admin/genresAdminPage/index.vue
index 67cbbec..47c060d 100644
--- a/software/src/pages/admin/genresAdminPage/index.vue
+++ b/software/src/pages/admin/genresAdminPage/index.vue
@@ -1,6 +1,53 @@
- Genres Admin Page
+
+
+
+
+ {{ band.name }}
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/software/src/pages/bands/bandsPage/bandFilterbar.vue b/software/src/pages/bands/bandsPage/bandFilterbar.vue
index d43d2f7..09c221c 100644
--- a/software/src/pages/bands/bandsPage/bandFilterbar.vue
+++ b/software/src/pages/bands/bandsPage/bandFilterbar.vue
@@ -3,8 +3,10 @@ import cardView from '@/components/basics/cardView.vue';
import { useBandStore } from '@/stores/band.store';
import outlinedButton from '@/components/basics/outlinedButton.vue';
import { GenreModel } from '@/data/models/acts/genreModel';
+import { useGenreStore } from '@/stores/genre.store';
const bandStore = useBandStore()
+const genreStore = useGenreStore()
function itemProps(item: GenreModel) {
return {
@@ -21,8 +23,8 @@ function itemProps(item: GenreModel) {
({
@@ -16,17 +15,11 @@ export const useBandStore = defineStore("bandStore", {
/** All information about a single band */
band: ref(new BandDetailsApiModel()),
- /** Genres to filter bands for */
- filteredGenres: ref>([]),
-
- /** All available genres from server */
- availableGenres: ref>([]),
-
/** Request to server sent, waiting for data response */
fetchInProgress: ref(false),
- /** Show or hide the edit dialog for edit a band */
- showBandEditDialog: ref(false)
+ /** Show or hide the edit dialog for edit a band or genre */
+ showEditDialog: ref(false)
}),
actions: {
@@ -34,17 +27,18 @@ export const useBandStore = defineStore("bandStore", {
* Get all bands from server
*/
async getBands() {
+ const genreStore = useGenreStore()
this.fetchInProgress = true
await fetchAllBands()
.then(result => {
this.bands = result.data.filter((band: BandApiModel) => {
- if (this.filteredGenres.length == 0) {
+ if (genreStore.filteredGenres.length == 0) {
return true
}
for (let bandGenre of band.genres) {
- for (let filteredGenres of this.filteredGenres) {
+ for (let filteredGenres of genreStore.filteredGenres) {
if (bandGenre.name == filteredGenres.name) {
return true
}
@@ -55,11 +49,6 @@ export const useBandStore = defineStore("bandStore", {
})
})
- await fetchAllGenres()
- .then(result => {
- this.availableGenres = result.data
- })
-
this.fetchInProgress = false
},
@@ -83,10 +72,10 @@ export const useBandStore = defineStore("bandStore", {
*/
newBand() {
this.band = new BandDetailsApiModel()
-
- this.showBandEditDialog = true
+ this.showEditDialog = true
},
+
/**
* Edit a band. Fetch all information about the band, opens the edit dialog
*
@@ -95,7 +84,7 @@ export const useBandStore = defineStore("bandStore", {
async editBand(name: string) {
await this.getBand(name)
- this.showBandEditDialog = true
+ this.showEditDialog = true
},
/**
@@ -112,7 +101,7 @@ export const useBandStore = defineStore("bandStore", {
feedbackStore.changeBanner(BannerStateEnum.BANDSAVEDSUCCESSFUL)
this.getBands()
- this.showBandEditDialog = false
+ this.showEditDialog = false
} else {
feedbackStore.changeBanner(BannerStateEnum.BANDSAVEDERROR)
}
@@ -124,7 +113,7 @@ export const useBandStore = defineStore("bandStore", {
feedbackStore.changeBanner(BannerStateEnum.BANDSAVEDSUCCESSFUL)
this.getBands()
- this.showBandEditDialog = false
+ this.showEditDialog = false
} else {
feedbackStore.changeBanner(BannerStateEnum.BANDSAVEDERROR)
}
diff --git a/software/src/stores/genre.store.ts b/software/src/stores/genre.store.ts
new file mode 100644
index 0000000..5874cd3
--- /dev/null
+++ b/software/src/stores/genre.store.ts
@@ -0,0 +1,53 @@
+import { fetchAllGenres } from "@/data/api/genreApi";
+import { GenreApiModel } from "@/data/models/acts/genreApiModel";
+import { defineStore } from "pinia";
+import { ref } from "vue";
+
+export const useGenreStore = defineStore("genreStore", {
+ state: () => ({
+ /** All available genres from server */
+ genres: ref>([]),
+
+ /** Currently edited genre */
+ genre: ref(new GenreApiModel()),
+
+ /** Genres to filter bands for */
+ filteredGenres: ref>([]),
+
+ showEditDialog: ref(false),
+ fetchInProgress: ref(false)
+ }),
+
+ actions: {
+ getGenres() {
+ this.fetchInProgress = true
+
+ fetchAllGenres()
+ .then(response => {
+ this.genres = response.data
+ this.fetchInProgress = false
+ })
+ },
+
+ /**
+ * Prepare edit dialog for new genre, opens it
+ */
+ newGenre() {
+ this.genre = new GenreApiModel()
+ this.showEditDialog = true
+ },
+
+ editGenre(genre: GenreApiModel) {
+ this.genre = genre
+ this.showEditDialog = true
+ },
+
+ saveGenre() {
+ // todo
+ },
+
+ deleteGenre(genre: GenreApiModel) {
+ // todo
+ }
+ }
+})
\ No newline at end of file