walletService.tsx 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306
  1. import axios from 'axios';
  2. import * as SecureStore from 'expo-secure-store';
  3. import { EXPO_PUBLIC_API_URL } from '@env';
  4. class WalletService {
  5. private apiUrl: string;
  6. constructor() {
  7. this.apiUrl = EXPO_PUBLIC_API_URL;
  8. if (!this.apiUrl) {
  9. throw new Error('API URL is not defined in environment variables');
  10. }
  11. }
  12. async getCouponForSpecificUser(userID: string) {
  13. try {
  14. const response = await axios.get(`${this.apiUrl}/clients/promotion/coupons/${userID}`, {
  15. headers: {
  16. Authorization: `Bearer ${await SecureStore.getItemAsync('accessToken')}`
  17. }
  18. });
  19. if (response.status === 200 || response.status === 201) {
  20. return response.data;
  21. } else {
  22. return false;
  23. }
  24. } catch (error) {
  25. console.error('Error in getCouponForSpecificUser:', error);
  26. throw error;
  27. }
  28. }
  29. async getCustomerInfo() {
  30. try {
  31. const response = await axios.get(`${this.apiUrl}/clients/customer`, {
  32. headers: {
  33. Authorization: `Bearer ${await SecureStore.getItemAsync('accessToken')}`
  34. }
  35. });
  36. if (response.status === 200 || response.status === 201) {
  37. const info = response.data;
  38. return info;
  39. } else {
  40. console.error('get customer info failed:', response.status);
  41. return false;
  42. }
  43. } catch (error) {
  44. if (axios.isAxiosError(error)) {
  45. console.error('get customer info error:', error.response?.data?.message || error.message);
  46. } else {
  47. console.error('An unexpected error occurred:', error);
  48. }
  49. return false;
  50. }
  51. }
  52. async getWalletBalance() {
  53. try {
  54. const response = await axios.get(`${this.apiUrl}/clients/customer/wallet`, {
  55. headers: {
  56. Authorization: `Bearer ${await SecureStore.getItemAsync('accessToken')}`
  57. }
  58. });
  59. if (response.status === 200) {
  60. const walletBalance = response.data.data;
  61. return walletBalance;
  62. } else {
  63. console.error('getWalletBalance failed:', response.status);
  64. return false;
  65. }
  66. } catch (error) {
  67. if (axios.isAxiosError(error)) {
  68. console.error('getWallet error:', error.response?.data?.message || error.message);
  69. } else {
  70. console.error('An unexpected error occurred:', error);
  71. }
  72. return false;
  73. }
  74. }
  75. async getOutTradeNo() {
  76. try {
  77. const response = await axios.get(`${this.apiUrl}/clients/qfpay/out_trade_no`, {
  78. headers: {
  79. Authorization: `Bearer ${await SecureStore.getItemAsync('accessToken')}`
  80. }
  81. });
  82. if (response.status === 200) {
  83. const outTradeNo = response.data.out_trade_no;
  84. return outTradeNo;
  85. } else {
  86. console.error('get outTradeNo failed:', response.status);
  87. return false;
  88. }
  89. } catch (error) {
  90. if (axios.isAxiosError(error)) {
  91. console.error('get outTradeNo error:', error.response?.data?.message || error.message);
  92. } else {
  93. console.error('An unexpected error occurred:', error);
  94. }
  95. return false;
  96. }
  97. }
  98. async getTransactionRecord() {
  99. try {
  100. const response = await axios.get(`${this.apiUrl}/clients/wallet/transaction/record`, {
  101. headers: {
  102. Authorization: `Bearer ${await SecureStore.getItemAsync('accessToken')}`
  103. }
  104. });
  105. if (response.status === 200) {
  106. const walletBalance = response.data;
  107. return walletBalance;
  108. } else {
  109. console.error('getWalletBalance failed:', response.status);
  110. return false;
  111. }
  112. } catch (error) {
  113. if (axios.isAxiosError(error)) {
  114. console.error('getWallet error:', error.response?.data?.message || error.message);
  115. } else {
  116. console.error('An unexpected error occurred:', error);
  117. }
  118. return false;
  119. }
  120. }
  121. async submitPayment(
  122. stationID: string,
  123. connector: string,
  124. user: string,
  125. book_time: string,
  126. end_time: string,
  127. total_power: string,
  128. total_fee: string,
  129. promotion_code: string,
  130. car: string,
  131. type?: string,
  132. is_ic_call?: boolean
  133. ) {
  134. try {
  135. const payload = {
  136. stationID,
  137. connector,
  138. user,
  139. book_time,
  140. end_time,
  141. total_power,
  142. total_fee,
  143. promotion_code,
  144. car,
  145. type,
  146. is_ic_call
  147. };
  148. const response = await axios.post(`${this.apiUrl}/clients/pay`, payload, {
  149. headers: {
  150. Authorization: `Bearer ${await SecureStore.getItemAsync('accessToken')}`
  151. }
  152. });
  153. if (response.status === 200 || response.status === 201) {
  154. return response.data;
  155. } else {
  156. return false;
  157. }
  158. } catch (error) {
  159. return false;
  160. }
  161. }
  162. async newSubmitPayment(
  163. stationID: string,
  164. connector: string,
  165. user: string,
  166. book_time: string,
  167. end_time: string,
  168. total_power: number,
  169. total_fee: number,
  170. promotion_code: string[],
  171. with_coupon: boolean,
  172. car: string,
  173. type?: string,
  174. is_ic_call?: boolean
  175. ) {
  176. try {
  177. const payload = {
  178. stationID,
  179. connector,
  180. user,
  181. book_time,
  182. end_time,
  183. total_power,
  184. total_fee,
  185. promotion_code,
  186. with_coupon,
  187. car,
  188. type,
  189. is_ic_call
  190. };
  191. const response = await axios.post(`${this.apiUrl}/clients/pay`, payload, {
  192. headers: {
  193. Authorization: `Bearer ${await SecureStore.getItemAsync('accessToken')}`
  194. }
  195. });
  196. if (response.data.status === 200 || response.data.status === 201) {
  197. return response.data.status;
  198. } else {
  199. return response.data;
  200. }
  201. } catch (error) {
  202. if (axios.isAxiosError(error)) {
  203. return {
  204. error: true,
  205. status: error.response?.status,
  206. message: error.response?.data?.message || error.message
  207. };
  208. } else {
  209. return {
  210. error: true,
  211. message: 'An unexpected error occurred'
  212. };
  213. }
  214. }
  215. }
  216. async selectPaymentType() {
  217. try {
  218. const response = await axios.get(`${this.apiUrl}/clients/qfpay/type`, {
  219. headers: {
  220. Authorization: `Bearer ${await SecureStore.getItemAsync('accessToken')}`
  221. }
  222. });
  223. if (response.status === 200 || response.status === 201) {
  224. const info = response.data;
  225. return info;
  226. } else {
  227. console.error('get customer info failed:', response.status);
  228. return false;
  229. }
  230. } catch (error) {
  231. if (axios.isAxiosError(error)) {
  232. console.error('get customer info error:', error.response?.data?.message || error.message);
  233. } else {
  234. console.error('An unexpected error occurred:', error);
  235. }
  236. return false;
  237. }
  238. }
  239. async submitPaymentAfterSelectingType(amount: number, pay_type: string, return_url?: string) {
  240. try {
  241. const response = await axios.get(
  242. `${this.apiUrl}/clients/qfpay/session?amount=${amount}&pay_type=${pay_type}&return_url=${return_url}`,
  243. {
  244. headers: {
  245. Authorization: `Bearer ${await SecureStore.getItemAsync('accessToken')}`
  246. }
  247. }
  248. );
  249. // if (response.status === 200 || response.status === 201) {
  250. if (response) {
  251. const info = response.data;
  252. return info;
  253. } else {
  254. console.error('get customer info failed:', response.status);
  255. return false;
  256. }
  257. } catch (error) {
  258. if (axios.isAxiosError(error)) {
  259. console.error('get customer info error:', error.response?.data?.message || error.message);
  260. } else {
  261. console.error('An unexpected error occurred:', error);
  262. }
  263. return false;
  264. }
  265. }
  266. async checkPaymentStatus(out_trade_no: string) {
  267. try {
  268. const response = await axios.get(`${this.apiUrl}/clients/qfpay/check/transaction/${out_trade_no}`, {
  269. headers: {
  270. Authorization: `Bearer ${await SecureStore.getItemAsync('accessToken')}`
  271. }
  272. });
  273. if (Array.isArray(response.data.data) && response.data.data.length > 0) {
  274. // If it's not empty, consider it a success and return the data
  275. return response.data.data;
  276. } else {
  277. // If it's an empty array, consider it false
  278. return false;
  279. }
  280. } catch (error) {
  281. if (axios.isAxiosError(error)) {
  282. console.error('check payment status error:', error.response?.data?.message || error.message);
  283. } else {
  284. console.error('An unexpected error occurred:', error);
  285. }
  286. return false;
  287. }
  288. }
  289. }
  290. export const walletService = new WalletService();