| 
									
										
										
										
											2021-08-06 16:28:12 -08:00
										 |  |  | import { useAsync, ref } from "@nuxtjs/composition-api"; | 
					
						
							| 
									
										
										
										
											2021-11-06 11:28:47 -08:00
										 |  |  | import { useUserApi } from "~/composables/api"; | 
					
						
							| 
									
										
										
										
											2021-08-06 16:28:12 -08:00
										 |  |  | import { UserIn, UserOut } from "~/types/api-types/user"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  | TODO: Potentiall combine useAllUsers and useUser by delaying the get all users functinality | 
					
						
							|  |  |  | Unsure how this could work but still be clear and functional. Perhaps by passing arguments to the useUsers function | 
					
						
							|  |  |  | to control whether the object is substantiated... but some of the others rely on it being substantiated...Will come back to this. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const useAllUsers = function () { | 
					
						
							| 
									
										
										
										
											2021-11-06 11:28:47 -08:00
										 |  |  |   const api = useUserApi(); | 
					
						
							| 
									
										
										
										
											2021-08-06 16:28:12 -08:00
										 |  |  |   const loading = ref(false); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function getAllUsers() { | 
					
						
							|  |  |  |     loading.value = true; | 
					
						
							|  |  |  |     const asyncKey = String(Date.now()); | 
					
						
							|  |  |  |     const allUsers = useAsync(async () => { | 
					
						
							|  |  |  |       const { data } = await api.users.getAll(); | 
					
						
							|  |  |  |       return data; | 
					
						
							|  |  |  |     }, asyncKey); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     loading.value = false; | 
					
						
							|  |  |  |     return allUsers; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   async function refreshAllUsers() { | 
					
						
							|  |  |  |     loading.value = true; | 
					
						
							|  |  |  |     const { data } = await api.users.getAll(); | 
					
						
							|  |  |  |     users.value = data; | 
					
						
							|  |  |  |     loading.value = false; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const users = getAllUsers(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return { users, refreshAllUsers }; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const useUser = function (refreshFunc: CallableFunction | null = null) { | 
					
						
							| 
									
										
										
										
											2021-11-06 11:28:47 -08:00
										 |  |  |   const api = useUserApi(); | 
					
						
							| 
									
										
										
										
											2021-08-06 16:28:12 -08:00
										 |  |  |   const loading = ref(false); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function getUser(id: string) { | 
					
						
							|  |  |  |     loading.value = true; | 
					
						
							|  |  |  |     const user = useAsync(async () => { | 
					
						
							|  |  |  |       const { data } = await api.users.getOne(id); | 
					
						
							|  |  |  |       return data; | 
					
						
							|  |  |  |     }, id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     loading.value = false; | 
					
						
							|  |  |  |     return user; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   async function createUser(payload: UserIn) { | 
					
						
							|  |  |  |     loading.value = true; | 
					
						
							|  |  |  |     const { data } = await api.users.createOne(payload); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     console.log(payload, data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (refreshFunc) { | 
					
						
							|  |  |  |       refreshFunc(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     loading.value = false; | 
					
						
							|  |  |  |     return data; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   async function deleteUser(id: string) { | 
					
						
							|  |  |  |     loading.value = true; | 
					
						
							|  |  |  |     const { data } = await api.users.deleteOne(id); | 
					
						
							|  |  |  |     loading.value = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (refreshFunc) { | 
					
						
							|  |  |  |       refreshFunc(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return data; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-23 18:57:24 -09:00
										 |  |  |   async function updateUser(itemId: string, user: UserOut) { | 
					
						
							| 
									
										
										
										
											2021-08-06 16:28:12 -08:00
										 |  |  |     loading.value = true; | 
					
						
							| 
									
										
										
										
											2021-11-23 18:57:24 -09:00
										 |  |  |     const { data } = await api.users.updateOne(itemId, user); | 
					
						
							| 
									
										
										
										
											2021-08-06 16:28:12 -08:00
										 |  |  |     loading.value = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (refreshFunc) { | 
					
						
							|  |  |  |       refreshFunc(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return data; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return { loading, getUser, deleteUser, updateUser, createUser }; | 
					
						
							|  |  |  | }; |