| 
									
										
										
										
											2021-09-12 11:05:09 -08:00
										 |  |  | import { useAsync, ref } from "@nuxtjs/composition-api"; | 
					
						
							|  |  |  | import { addDays, subDays, format } from "date-fns"; | 
					
						
							|  |  |  | import { useAsyncKey } from "./use-utils"; | 
					
						
							| 
									
										
										
										
											2021-11-06 11:28:47 -08:00
										 |  |  | import { useUserApi } from "~/composables/api"; | 
					
						
							| 
									
										
										
										
											2021-09-12 11:05:09 -08:00
										 |  |  | import { CreateMealPlan, UpdateMealPlan } from "~/api/class-interfaces/group-mealplan"; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-20 14:30:38 -09:00
										 |  |  | export type MealType = "breakfast" | "lunch" | "dinner" | "snack"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const planTypeOptions = [ | 
					
						
							|  |  |  |   { text: "Breakfast", value: "breakfast" }, | 
					
						
							|  |  |  |   { text: "Lunch", value: "lunch" }, | 
					
						
							|  |  |  |   { text: "Dinner", value: "dinner" }, | 
					
						
							|  |  |  |   { text: "Snack", value: "snack" }, | 
					
						
							|  |  |  | ]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-12 11:05:09 -08:00
										 |  |  | export const useMealplans = function () { | 
					
						
							| 
									
										
										
										
											2021-11-06 11:28:47 -08:00
										 |  |  |   const api = useUserApi(); | 
					
						
							| 
									
										
										
										
											2021-09-12 11:05:09 -08:00
										 |  |  |   const loading = ref(false); | 
					
						
							|  |  |  |   const validForm = ref(true); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const actions = { | 
					
						
							|  |  |  |     getAll() { | 
					
						
							|  |  |  |       loading.value = true; | 
					
						
							|  |  |  |       const units = useAsync(async () => { | 
					
						
							|  |  |  |         const query = { | 
					
						
							|  |  |  |           start: format(subDays(new Date(), 30), "yyyy-MM-dd"), | 
					
						
							|  |  |  |           limit: format(addDays(new Date(), 30), "yyyy-MM-dd"), | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         // @ts-ignore
 | 
					
						
							|  |  |  |         const { data } = await api.mealplans.getAll(query.start, query.limit); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return data; | 
					
						
							|  |  |  |       }, useAsyncKey()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       loading.value = false; | 
					
						
							|  |  |  |       return units; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     async refreshAll() { | 
					
						
							|  |  |  |       loading.value = true; | 
					
						
							|  |  |  |       const query = { | 
					
						
							|  |  |  |         start: format(subDays(new Date(), 30), "yyyy-MM-dd"), | 
					
						
							|  |  |  |         limit: format(addDays(new Date(), 30), "yyyy-MM-dd"), | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |       // @ts-ignore
 | 
					
						
							|  |  |  |       const { data } = await api.mealplans.getAll(query.start, query.limit); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (data) { | 
					
						
							|  |  |  |         mealplans.value = data; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       loading.value = false; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     async createOne(payload: CreateMealPlan) { | 
					
						
							|  |  |  |       loading.value = true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const { data } = await api.mealplans.createOne(payload); | 
					
						
							|  |  |  |       if (data) { | 
					
						
							|  |  |  |         this.refreshAll(); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       loading.value = false; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     async updateOne(updateData: UpdateMealPlan) { | 
					
						
							|  |  |  |       if (!updateData.id) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       loading.value = true; | 
					
						
							|  |  |  |       // @ts-ignore
 | 
					
						
							|  |  |  |       const { data } = await api.mealplans.updateOne(updateData.id, updateData); | 
					
						
							|  |  |  |       if (data) { | 
					
						
							|  |  |  |         this.refreshAll(); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       loading.value = false; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async deleteOne(id: string | number) { | 
					
						
							|  |  |  |       loading.value = true; | 
					
						
							|  |  |  |       const { data } = await api.mealplans.deleteOne(id); | 
					
						
							|  |  |  |       if (data) { | 
					
						
							|  |  |  |         this.refreshAll(); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2021-11-20 14:30:38 -09:00
										 |  |  | 
 | 
					
						
							|  |  |  |     async setType(payload: UpdateMealPlan, typ: MealType) { | 
					
						
							|  |  |  |       payload.entryType = typ; | 
					
						
							|  |  |  |       await this.updateOne(payload); | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2021-09-12 11:05:09 -08:00
										 |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const mealplans = actions.getAll(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-20 14:30:38 -09:00
										 |  |  |   return { mealplans, actions, validForm, loading }; | 
					
						
							| 
									
										
										
										
											2021-09-12 11:05:09 -08:00
										 |  |  | }; |