| 
									
										
										
										
											2021-05-29 15:54:18 -08:00
										 |  |  | <template> | 
					
						
							| 
									
										
										
										
											2021-07-09 14:33:23 -08:00
										 |  |  |   <v-tooltip bottom nudge-right="50" :color="buttonStyle ? 'info' : 'secondary'"> | 
					
						
							| 
									
										
										
										
											2021-08-01 19:24:47 -08:00
										 |  |  |     <template #activator="{ on, attrs }"> | 
					
						
							| 
									
										
										
										
											2021-06-12 14:59:14 +08:00
										 |  |  |       <v-btn | 
					
						
							|  |  |  |         v-if="isFavorite || showAlways" | 
					
						
							| 
									
										
										
										
											2021-08-01 19:24:47 -08:00
										 |  |  |         small | 
					
						
							| 
									
										
										
										
											2021-07-09 14:33:23 -08:00
										 |  |  |         :color="buttonStyle ? 'info' : 'secondary'" | 
					
						
							| 
									
										
										
										
											2021-06-12 14:59:14 +08:00
										 |  |  |         :icon="!buttonStyle" | 
					
						
							|  |  |  |         :fab="buttonStyle" | 
					
						
							|  |  |  |         v-bind="attrs" | 
					
						
							| 
									
										
										
										
											2021-08-01 19:24:47 -08:00
										 |  |  |         @click.prevent="toggleFavorite" | 
					
						
							| 
									
										
										
										
											2021-06-12 14:59:14 +08:00
										 |  |  |         v-on="on" | 
					
						
							|  |  |  |       > | 
					
						
							| 
									
										
										
										
											2021-07-09 14:33:23 -08:00
										 |  |  |         <v-icon :small="!buttonStyle" :color="buttonStyle ? 'white' : 'secondary'"> | 
					
						
							| 
									
										
										
										
											2021-06-16 18:55:32 -08:00
										 |  |  |           {{ isFavorite ? $globals.icons.heart : $globals.icons.heartOutline }} | 
					
						
							| 
									
										
										
										
											2021-06-12 14:59:14 +08:00
										 |  |  |         </v-icon> | 
					
						
							|  |  |  |       </v-btn> | 
					
						
							|  |  |  |     </template> | 
					
						
							|  |  |  |     <span>{{ isFavorite ? $t("recipe.remove-from-favorites") : $t("recipe.add-to-favorites") }}</span> | 
					
						
							|  |  |  |   </v-tooltip> | 
					
						
							| 
									
										
										
										
											2021-05-29 15:54:18 -08:00
										 |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | import { api } from "@/api"; | 
					
						
							|  |  |  | export default { | 
					
						
							|  |  |  |   props: { | 
					
						
							|  |  |  |     slug: { | 
					
						
							| 
									
										
										
										
											2021-08-01 19:24:47 -08:00
										 |  |  |       type: String, | 
					
						
							| 
									
										
										
										
											2021-05-29 15:54:18 -08:00
										 |  |  |       default: "", | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     showAlways: { | 
					
						
							|  |  |  |       type: Boolean, | 
					
						
							|  |  |  |       default: false, | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     buttonStyle: { | 
					
						
							|  |  |  |       type: Boolean, | 
					
						
							|  |  |  |       default: false, | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   computed: { | 
					
						
							|  |  |  |     user() { | 
					
						
							| 
									
										
										
										
											2021-08-02 22:15:11 -08:00
										 |  |  |       return this.$auth.user; | 
					
						
							| 
									
										
										
										
											2021-05-29 15:54:18 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     isFavorite() { | 
					
						
							| 
									
										
										
										
											2021-08-02 22:15:11 -08:00
										 |  |  |       return this.$auth.user.favoriteRecipes.includes(this.slug); | 
					
						
							| 
									
										
										
										
											2021-05-29 15:54:18 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   methods: { | 
					
						
							|  |  |  |     async toggleFavorite() { | 
					
						
							|  |  |  |       if (!this.isFavorite) { | 
					
						
							| 
									
										
										
										
											2021-08-02 22:15:11 -08:00
										 |  |  |         await api.users.addFavorite(this.$auth.user.id, this.slug); | 
					
						
							| 
									
										
										
										
											2021-05-29 15:54:18 -08:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2021-08-02 22:15:11 -08:00
										 |  |  |         await api.users.removeFavorite(this.$auth.user.id, this.slug); | 
					
						
							| 
									
										
										
										
											2021-05-29 15:54:18 -08:00
										 |  |  |       } | 
					
						
							|  |  |  |       this.$store.dispatch("requestUserData"); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  | </style> |