Fix order view

This commit is contained in:
2024-09-20 15:30:40 +02:00
parent 871f8cac7a
commit c27dc747b7
7 changed files with 34 additions and 20 deletions

View File

@@ -0,0 +1,7 @@
import axios from "axios"
const BASE_URL = "http://localhost:3000/orders"
export async function getUserOrders(userId: number) {
return axios.get(BASE_URL + "/" + userId)
}

View File

@@ -0,0 +1,9 @@
import { OrderedItemModel } from "./orderedItemModel"
export class OrderModel {
accountId: number
totalPrice: number
shippingProgress: number
orderItem: Array<OrderedItemModel>
createdAt: string
}

View File

@@ -1,6 +1,8 @@
import { ProductModel } from "./productModel"
export class OrderedItemModel {
orderId: number = -1
productId: number = -1
product: ProductModel
quantity: number = 1
totalPrice: number = 0
}

View File

@@ -6,13 +6,16 @@ import { AccountModel } from "../models/accountModel";
import { loginAccount, registerAccount, updateAccount } from "../api/accountApi";
import { useFeedbackStore } from "./feedbackStore";
import { BannerStateEnum } from "../enums/bannerStateEnum";
import { OrderModel } from "../models/orderModel";
import { getUserOrders } from "../api/orderApi";
export const useUserStore = defineStore('userStore', {
state: () => ({
theme: useLocalStorage<ThemeEnum>("hackmycart/userStore/theme", ThemeEnum.DARKRED),
language: useLocalStorage<LanguageEnum>("hackmycart/userStore/language", LanguageEnum.GERMAN),
userAccount: useLocalStorage<AccountModel>("hackmycart/userStore/userAccount", new AccountModel()),
loggedIn: useLocalStorage<Boolean>("hackmycart/userStore/loggedIn", false)
loggedIn: useLocalStorage<Boolean>("hackmycart/userStore/loggedIn", false),
orders: useLocalStorage<Array<OrderModel>>("hackmycart/userStore/orders", [])
}),
actions: {
@@ -20,11 +23,16 @@ export const useUserStore = defineStore('userStore', {
const feedbackStore = useFeedbackStore()
await loginAccount(username, password)
.then(result => {
this.userAccount = result.data.account
.then(async result => {
this.userAccount = result.data
this.loggedIn = true
feedbackStore.changeBanner(BannerStateEnum.ACCOUNTLOGINSUCCESSFUL)
await getUserOrders(result.data.id)
.then(result => {
this.orders = result.data
})
})
.catch(error => {
this.loggedIn = false