some fixes
This commit is contained in:
@@ -2,7 +2,7 @@ import axios from "axios";
|
||||
import FormData from "form-data";
|
||||
import { useAuthStore } from "@/store/authStore";
|
||||
|
||||
// const API_URL = "https://testowe.zikor.pl/api/v1";
|
||||
// const API_URL = "https://hopp.zikor.pl/api/v1";
|
||||
|
||||
const API_URL = "https://hopp.zikor.pl/api/v1";
|
||||
|
||||
@@ -36,7 +36,9 @@ export async function createNotice(notice) {
|
||||
const { token } = useAuthStore.getState();
|
||||
const headers = token ? { Authorization: `Bearer ${token}` } : {};
|
||||
try {
|
||||
const response = await axios.post(`${API_URL}/notices/add`, notice, {headers: headers});
|
||||
const response = await axios.post(`${API_URL}/notices/add`, notice, {
|
||||
headers: headers,
|
||||
});
|
||||
|
||||
if (response.data.noticeId !== null) {
|
||||
for (const imageUri of notice.image) {
|
||||
@@ -71,7 +73,9 @@ export async function getAllImagesByNoticeId(noticeId) {
|
||||
const { token } = useAuthStore.getState();
|
||||
const headers = token ? { Authorization: `Bearer ${token}` } : {};
|
||||
try {
|
||||
const listResponse = await axios.get(`${API_URL}/images/list/${noticeId}`, {headers: headers});
|
||||
const listResponse = await axios.get(`${API_URL}/images/list/${noticeId}`, {
|
||||
headers: headers,
|
||||
});
|
||||
|
||||
if (listResponse.data && listResponse.data.length > 0) {
|
||||
return listResponse.data.map((imageName) => ({
|
||||
|
||||
@@ -1,6 +1,4 @@
|
||||
import axios from "axios";
|
||||
import FormData from "form-data";
|
||||
|
||||
import { useAuthStore } from "@/store/authStore";
|
||||
|
||||
const API_URL = "https://hopp.zikor.pl/api/v1/orders";
|
||||
@@ -9,17 +7,16 @@ export async function createOrder(noticeId, orderType) {
|
||||
const { token } = useAuthStore.getState();
|
||||
const headers = token ? { Authorization: `Bearer ${token}` } : {};
|
||||
const clientId = 1;
|
||||
|
||||
try {
|
||||
const response = await axios.post(
|
||||
`${API_URL}/add`,
|
||||
{ clientId, noticeId, orderType },
|
||||
{ clientId: clientId, noticeId: noticeId, orderType: orderType },
|
||||
{
|
||||
headers: {
|
||||
"Content-Type": "application/json",
|
||||
...headers,
|
||||
},
|
||||
headers: headers,
|
||||
}
|
||||
);
|
||||
|
||||
return response.data;
|
||||
} catch (error) {
|
||||
console.log("Error", error.response?.data, error.response?.status);
|
||||
@@ -33,13 +30,10 @@ export async function createPayment(orderId) {
|
||||
const clientId = 1;
|
||||
try {
|
||||
const response = await axios.post(
|
||||
`${API_URL}/token`,
|
||||
`${API_URL}/token?orderId=${orderId}`,
|
||||
{},
|
||||
{
|
||||
headers: {
|
||||
"Content-Type": "application/json",
|
||||
...headers,
|
||||
},
|
||||
headers: headers,
|
||||
}
|
||||
);
|
||||
return response.data;
|
||||
@@ -49,13 +43,30 @@ export async function createPayment(orderId) {
|
||||
}
|
||||
}
|
||||
|
||||
export async function getOrder(orderId) {
|
||||
const { token } = useAuthStore.getState();
|
||||
const headers = token ? { Authorization: `Bearer ${token}` } : {};
|
||||
|
||||
try {
|
||||
const response = await axios.get(`${API_URL}/get/${orderId}`, { headers });
|
||||
return response.data;
|
||||
} catch (error) {
|
||||
console.error(
|
||||
"Error fetching order:",
|
||||
error.response?.data,
|
||||
error.response?.status
|
||||
);
|
||||
throw error;
|
||||
}
|
||||
}
|
||||
|
||||
export async function listOrders() {
|
||||
const { token } = useAuthStore.getState();
|
||||
const headers = token ? { Authorization: `Bearer ${token}` } : {};
|
||||
|
||||
try {
|
||||
const response = await axios.get(`${API_URL}/get/all`, { headers });
|
||||
return response.data; // to będzie tablica OrderWithPaymentsDTO
|
||||
return response.data;
|
||||
} catch (error) {
|
||||
console.error(
|
||||
"Error fetching orders:",
|
||||
|
||||
@@ -35,4 +35,4 @@ export async function getWishlist() {
|
||||
throw error;
|
||||
}
|
||||
}
|
||||
``
|
||||
``;
|
||||
|
||||
@@ -3,11 +3,12 @@ import { Ionicons } from "@expo/vector-icons";
|
||||
import { useAuthStore } from "@/store/authStore";
|
||||
|
||||
export default function TabLayout() {
|
||||
const token = useAuthStore((state) => state.token);
|
||||
const { token } = useAuthStore.getState();
|
||||
|
||||
if (!token) {
|
||||
return <Redirect href="/login" />;
|
||||
}
|
||||
|
||||
return (
|
||||
<Tabs
|
||||
screenOptions={{
|
||||
|
||||
@@ -7,7 +7,7 @@ import { Text } from "@/components/ui/text";
|
||||
import { VStack } from "@/components/ui/vstack";
|
||||
import { ActivityIndicator, FlatList } from "react-native";
|
||||
import { useEffect, useState, useRef } from "react";
|
||||
import { createOrder, createPayment } from "@/api/order";
|
||||
import { createOrder, createPayment, getOrder } from "@/api/order";
|
||||
import { Linking } from "react-native";
|
||||
import { Ionicons } from "@expo/vector-icons";
|
||||
import { useToast, Toast, ToastTitle } from "@/components/ui/toast";
|
||||
@@ -23,13 +23,20 @@ export default function UserNotices() {
|
||||
const [toastId, setToastId] = useState(0);
|
||||
const { user_id } = useAuthStore.getState();
|
||||
const currentUserId = user_id;
|
||||
const [orderId, setOrderId] = useState(null);
|
||||
|
||||
useEffect(() => {
|
||||
if (!isRedirecting) return;
|
||||
const subscription = AppState.addEventListener("change", (state) => {
|
||||
if (state === "active") {
|
||||
(async () => {
|
||||
const lastOrder = await getOrder(orderId);
|
||||
const lastPayments = lastOrder.payments;
|
||||
const paymentStatus =
|
||||
lastPayments.length > 0
|
||||
? lastPayments[lastPayments.length - 1].status
|
||||
: null;
|
||||
setIsRedirecting(false);
|
||||
const paymentStatus = "CORRECT";
|
||||
if (paymentStatus === "INCORRECT") {
|
||||
showNewToast("Płatność została anulowana.");
|
||||
} else if (paymentStatus === "CORRECT") {
|
||||
@@ -37,12 +44,12 @@ export default function UserNotices() {
|
||||
} else {
|
||||
showNewToast("Płatność jeszcze nie wpłynęła.");
|
||||
}
|
||||
})();
|
||||
}
|
||||
|
||||
appState.current = state;
|
||||
});
|
||||
return () => subscription.remove();
|
||||
}, [isRedirecting, toast]);
|
||||
}, [isRedirecting, toast, orderId]);
|
||||
|
||||
useEffect(() => {
|
||||
const loadNotices = async () => {
|
||||
@@ -81,23 +88,23 @@ export default function UserNotices() {
|
||||
try {
|
||||
const result = await createOrder(noticeId, type);
|
||||
if (result) {
|
||||
setOrderId(result);
|
||||
try {
|
||||
const paymentResult = await createPayment(); //trzeba dodać orderId
|
||||
const paymentResult = await createPayment(result);
|
||||
if (paymentResult) {
|
||||
setIsRedirecting(true);
|
||||
await Linking.openURL(paymentResult);
|
||||
setWaitingForPayment(true);
|
||||
} else {
|
||||
console.log(`Nie udało się aktywować ogłoszenia ${noticeId}.`);
|
||||
console.log(`Nie udało się aktywować ogłoszenia 4 ${noticeId}.`);
|
||||
}
|
||||
} catch (err) {
|
||||
console.log("Błąd podczas aktywacji ogłoszenia:", err);
|
||||
// console.log("Błąd podczas aktywacji ogłoszenia 3:", err);
|
||||
}
|
||||
} else {
|
||||
console.log(`Nie udało się aktywować ogłoszenia ${noticeId}.`);
|
||||
// console.log(`Nie udało się aktywować ogłoszenia 2 ${noticeId}.`);
|
||||
}
|
||||
} catch (err) {
|
||||
console.log("Błąd podczas aktywacji ogłoszenia:", err);
|
||||
console.log("Błąd podczas aktywacji ogłoszenia 1:", err);
|
||||
}
|
||||
}
|
||||
};
|
||||
@@ -168,10 +175,14 @@ export default function UserNotices() {
|
||||
size="md"
|
||||
variant="solid"
|
||||
action="primary"
|
||||
onPress={() => handleOrder(item.noticeId, "ACTIVATE")}
|
||||
onPress={() => handleOrder(item.noticeId, "ACTIVATION")}
|
||||
>
|
||||
<ButtonText>Aktywuj</ButtonText>
|
||||
<Ionicons name="arrow-redo-outline" size={14} color="#fff" />
|
||||
<Ionicons
|
||||
name="arrow-redo-outline"
|
||||
size={14}
|
||||
color="#fff"
|
||||
/>
|
||||
</Button>
|
||||
)}
|
||||
</Box>
|
||||
|
||||
@@ -32,11 +32,8 @@ export default function Home() {
|
||||
}, [token, fetchNotices]);
|
||||
|
||||
const notices = useNoticesStore((state) => state.notices);
|
||||
// console.log("Notices:", notices);
|
||||
// console.log("Notices length:", notices.length);
|
||||
|
||||
const activeNotices = notices.filter((notice) => notice.status === "ACTIVE");
|
||||
// console.log("Activer Notices:", activeNotices.length);
|
||||
const latestNotices = [...activeNotices]
|
||||
.sort((a, b) => new Date(b.publishDate) - new Date(a.publishDate))
|
||||
.slice(0, 6);
|
||||
|
||||
@@ -10,22 +10,22 @@ let interceptorInitialized = false;
|
||||
export const useAuthStore = create(
|
||||
persist(
|
||||
(set, get) => {
|
||||
if (!interceptorInitialized.current) {
|
||||
axios.interceptors.response.use(
|
||||
(response) => response,
|
||||
(error) => {
|
||||
if (
|
||||
(error.response && error.response.status === 401) ||
|
||||
error.response.status === 403
|
||||
) {
|
||||
set({user_id: null, token: null, isLoading: false});
|
||||
delete axios.defaults.headers.common["Authorization"];
|
||||
}
|
||||
return Promise.reject(error);
|
||||
}
|
||||
);
|
||||
interceptorInitialized = true;
|
||||
}
|
||||
// if (!interceptorInitialized.current) {
|
||||
// axios.interceptors.response.use(
|
||||
// (response) => response,
|
||||
// (error) => {
|
||||
// if (
|
||||
// (error.response && error.response.status === 401) ||
|
||||
// error.response.status === 403
|
||||
// ) {
|
||||
// set({ user_id: null, token: null, isLoading: false });
|
||||
// delete axios.defaults.headers.common["Authorization"];
|
||||
// }
|
||||
// return Promise.reject(error);
|
||||
// }
|
||||
// );
|
||||
// interceptorInitialized = true;
|
||||
// }
|
||||
return {
|
||||
user_id: null,
|
||||
token: null,
|
||||
|
||||
Reference in New Issue
Block a user