[Update] Navigation menu
This commit is contained in:
		
							parent
							
								
									e615058a51
								
							
						
					
					
						commit
						538c96e6b0
					
				| @ -1,8 +1,8 @@ | |||||||
| APP_NAME=Laravel | APP_NAME=Abbauf-Kasir | ||||||
| APP_ENV=local | APP_ENV=local | ||||||
| APP_KEY= | APP_KEY= | ||||||
| APP_DEBUG=true | APP_DEBUG=true | ||||||
| APP_URL=http://localhost | APP_URL=http://localhost:8000 | ||||||
| 
 | 
 | ||||||
| APP_LOCALE=en | APP_LOCALE=en | ||||||
| APP_FALLBACK_LOCALE=en | APP_FALLBACK_LOCALE=en | ||||||
|  | |||||||
| @ -37,7 +37,7 @@ class DatabaseSeeder extends Seeder | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         $kategoriList = ['cincin', 'gelang rantai', 'gelang bulat', 'kalung', 'liontin', 'anting', 'giwang']; |         $kategoriList = ['Cincin', 'Gelang Rantai', 'Gelang Bulat', 'Kalung', 'Liontin', 'Anting', 'Giwang']; | ||||||
|         foreach ($kategoriList as $kategori) { |         foreach ($kategoriList as $kategori) { | ||||||
|             Kategori::factory()->create([ |             Kategori::factory()->create([ | ||||||
|                 'nama' => $kategori |                 'nama' => $kategori | ||||||
| @ -50,7 +50,8 @@ class DatabaseSeeder extends Seeder | |||||||
|             $fotoData = []; |             $fotoData = []; | ||||||
|             for ($i = 0; $i < $jumlah_foto; $i++) { |             for ($i = 0; $i < $jumlah_foto; $i++) { | ||||||
|                 $fotoData[] = [ |                 $fotoData[] = [ | ||||||
|                     'url' => 'https://random-image-pepebigotes.vercel.app/api/random-image' |                     // 'url' => 'https://random-image-pepebigotes.vercel.app/api/random-image'
 | ||||||
|  |                     'url' => 'https://static.promediateknologi.id/crop/0x0:0x0/0x0/webp/photo/p2/255/2024/12/10/Screenshot_2024-12-10-11-50-18-88_1c337646f29875672b5a61192b9010f9-1-1282380831.jpg' | ||||||
|                 ]; |                 ]; | ||||||
|             } |             } | ||||||
|             $produk->foto()->createMany($fotoData); |             $produk->foto()->createMany($fotoData); | ||||||
|  | |||||||
							
								
								
									
										1538
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1538
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -4,16 +4,17 @@ | |||||||
|     "type": "module", |     "type": "module", | ||||||
|     "scripts": { |     "scripts": { | ||||||
|         "build": "vite build", |         "build": "vite build", | ||||||
|         "dev": "vite" |         "dev": "concurrently \"php artisan serve\" \"vite\"" | ||||||
|     }, |     }, | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@tailwindcss/vite": "^4.0.0", |         "@tailwindcss/vite": "^4.0.0", | ||||||
|         "@vitejs/plugin-vue": "^6.0.1", |         "@vitejs/plugin-vue": "^6.0.1", | ||||||
|         "axios": "^1.11.0", |         "axios": "^1.11.0", | ||||||
|         "concurrently": "^9.0.1", |         "concurrently": "^9.2.1", | ||||||
|         "laravel-vite-plugin": "^2.0.0", |         "laravel-vite-plugin": "^2.0.0", | ||||||
|         "tailwindcss": "^4.0.0", |         "tailwindcss": "^4.0.0", | ||||||
|         "vite": "^7.0.4" |         "vite": "^7.0.4", | ||||||
|  |         "vite-plugin-vue-devtools": "^8.0.1" | ||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "vue": "^3.5.19", |         "vue": "^3.5.19", | ||||||
|  | |||||||
| @ -1,95 +0,0 @@ | |||||||
| <script setup> |  | ||||||
| import { ref } from "vue"; |  | ||||||
| import logo from "../../images/logo.png"; |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| const isOpen = ref(false); |  | ||||||
| 
 |  | ||||||
| const items = [ |  | ||||||
|   { label: "Kasir", route: "/kasir" }, |  | ||||||
|   { label: "Laporan", route: "/laporan" }, |  | ||||||
|   { label: "Akun", route: "/akun" }, |  | ||||||
| ]; |  | ||||||
| 
 |  | ||||||
| const subItems = [ |  | ||||||
|   { label: "Brankas", route: "/brankas" }, |  | ||||||
|   { label: "Nampan", route: "/nampan" }, |  | ||||||
|   { label: "Produk", route: "/produk" }, |  | ||||||
|   { label: "Sales", route: "/sales" }, |  | ||||||
| ]; |  | ||||||
| 
 |  | ||||||
| const toggleDropdown = () => { |  | ||||||
|   isOpen.value = !isOpen.value; |  | ||||||
| }; |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <template> |  | ||||||
|   <div class="h-25 shadow-lg shadow-D rounded-b-md"> |  | ||||||
|     <div class="bg-D h-5 rounded-b-md shadow-lg"> |  | ||||||
|       <div class="h-15"></div> |  | ||||||
|       <div class="relative"> |  | ||||||
|           <div class="w-full px-50 flex justify-between items-center h-5 relative"> |  | ||||||
|             <div class="absolute left-[50%]"> |  | ||||||
|                 <img :src="logo" alt="Logo" class="h-12 w-auto" /> |  | ||||||
|             </div> |  | ||||||
| 
 |  | ||||||
|             <!-- 🔹 LEFT MENU --> |  | ||||||
|             <div class="flex items-center gap-10"> |  | ||||||
|               <!-- Dropdown khusus "Manajemen Produk" --> |  | ||||||
|               <div class="relative"> |  | ||||||
|                 <button |  | ||||||
|                   @click="toggleDropdown" |  | ||||||
|                   class="text-center text-lg text-D hover:underline cursor-pointer" |  | ||||||
|                 > |  | ||||||
|                   Manajemen Produk |  | ||||||
|                 </button> |  | ||||||
| 
 |  | ||||||
|                 <!-- isi dropdown --> |  | ||||||
|                 <div |  | ||||||
|                   v-if="isOpen" |  | ||||||
|                   class="absolute left-0 mt-2 w-48 bg-white border rounded-md shadow-lg z-50" |  | ||||||
|                 > |  | ||||||
|                   <ul> |  | ||||||
|                     <li |  | ||||||
|                       v-for="(sub, index) in subItems" |  | ||||||
|                       :key="index" |  | ||||||
|                       class="px-4 py-2 hover:bg-A cursor-pointer" |  | ||||||
|                     > |  | ||||||
|                       <router-link :to="sub.route" class="block w-full h-full"> |  | ||||||
|                         {{ sub.label }} |  | ||||||
|                       </router-link> |  | ||||||
|                     </li> |  | ||||||
|                   </ul> |  | ||||||
|                 </div> |  | ||||||
|               </div> |  | ||||||
| 
 |  | ||||||
|               <!-- Menu Kasir --> |  | ||||||
|               <router-link |  | ||||||
|                 :to="items[0].route" |  | ||||||
|                 class="text-center text-lg text-D hover:underline cursor-pointer" |  | ||||||
|               > |  | ||||||
|                 {{ items[0].label }} |  | ||||||
|               </router-link> |  | ||||||
|             </div> |  | ||||||
| 
 |  | ||||||
|             <!-- 🔹 RIGHT MENU --> |  | ||||||
|             <div class="flex items-center gap-8"> |  | ||||||
|               <router-link |  | ||||||
|                 :to="items[1].route" |  | ||||||
|                 class="text-center text-lg text-D hover:underline cursor-pointer" |  | ||||||
|               > |  | ||||||
|                 {{ items[1].label }} |  | ||||||
|               </router-link> |  | ||||||
|               <router-link |  | ||||||
|                 :to="items[2].route" |  | ||||||
|                 class="text-center text-lg text-D hover:underline cursor-pointer" |  | ||||||
|               > |  | ||||||
|                 {{ items[2].label }} |  | ||||||
|               </router-link> |  | ||||||
|             </div> |  | ||||||
| 
 |  | ||||||
|           </div> |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
							
								
								
									
										68
									
								
								resources/js/components/NavDesktop.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								resources/js/components/NavDesktop.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,68 @@ | |||||||
|  | <script setup> | ||||||
|  | import { inject } from "vue"; | ||||||
|  | 
 | ||||||
|  | const { | ||||||
|  |   logo, | ||||||
|  |   items, | ||||||
|  |   isOpen, | ||||||
|  |   toggleDropdown, | ||||||
|  |   logout | ||||||
|  | } = inject('navigationData'); | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <!-- Desktop Navbar --> | ||||||
|  |   <div class="hidden md:block shadow-lg shadow-D rounded-b-md"> | ||||||
|  |     <div class="bg-D h-5 rounded-b-md shadow-lg"></div> | ||||||
|  |     <div class="relative rounded-b-md shadow-lg"> | ||||||
|  |       <!-- Logo Row --> | ||||||
|  |       <div class="flex justify-center items-center"> | ||||||
|  |         <img :src="logo" alt="Logo" class="h-12 w-auto" /> | ||||||
|  |       </div> | ||||||
|  | 
 | ||||||
|  |       <!-- Menu Row --> | ||||||
|  |       <div class="px-8 pb-4"> | ||||||
|  |         <div class="flex justify-around items-center gap-4"> | ||||||
|  |           <template v-for="(item, index) in items" :key="index"> | ||||||
|  | 
 | ||||||
|  |             <div v-if="item.subItems" class="relative flex-1"> | ||||||
|  |               <button @click="toggleDropdown(index)" | ||||||
|  |                 class="w-full text-center text-lg text-D hover:underline cursor-pointer flex items-center justify-center gap-2 transition-colors duration-200 py-2"> | ||||||
|  |                 {{ item.label }} | ||||||
|  |                 <svg :class="{ 'rotate-180': openDropdownIndex === index }" | ||||||
|  |                   class="w-4 h-4 transition-transform duration-200" fill="none" stroke="currentColor" | ||||||
|  |                   viewBox="0 0 24 24"> | ||||||
|  |                   <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19 9l-7 7-7-7" /> | ||||||
|  |                 </svg> | ||||||
|  |               </button> | ||||||
|  | 
 | ||||||
|  |               <div v-if="openDropdownIndex === index" | ||||||
|  |                 class="absolute left-0 mt-2 w-full bg-white border rounded-md shadow-lg z-50"> | ||||||
|  |                 <ul> | ||||||
|  |                   <li v-for="(sub, subIndex) in item.subItems" :key="subIndex" | ||||||
|  |                     class="hover:bg-A transition-colors duration-200"> | ||||||
|  |                     <router-link :to="sub.route" class="block w-full h-full px-4 py-2 text-D"> | ||||||
|  |                       {{ sub.label }} | ||||||
|  |                     </router-link> | ||||||
|  |                   </li> | ||||||
|  |                 </ul> | ||||||
|  |               </div> | ||||||
|  |             </div> | ||||||
|  | 
 | ||||||
|  |             <router-link v-else :to="item.route" | ||||||
|  |               class="flex-1 text-center text-lg text-D hover:underline cursor-pointer transition-colors duration-200 py-2"> | ||||||
|  |               {{ item.label }} | ||||||
|  |             </router-link> | ||||||
|  |           </template> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  | 
 | ||||||
|  |       <div class="absolute top-4 right-8"> | ||||||
|  |         <button @click="logout" | ||||||
|  |           class="text-center font-bold text-lg text-red-400 hover:underline hover:text-red-600 cursor-pointer transition-colors duration-200"> | ||||||
|  |           Logout | ||||||
|  |         </button> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
							
								
								
									
										94
									
								
								resources/js/components/NavMobile.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								resources/js/components/NavMobile.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,94 @@ | |||||||
|  | <script setup> | ||||||
|  | import { inject } from "vue"; | ||||||
|  | 
 | ||||||
|  | const { | ||||||
|  |   logo, | ||||||
|  |   items, | ||||||
|  |   isOpen, | ||||||
|  |   isMobileMenuOpen, | ||||||
|  |   toggleDropdown, | ||||||
|  |   toggleMobileMenu, | ||||||
|  |   closeMobileMenu, | ||||||
|  |   logout | ||||||
|  | } = inject('navigationData'); | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <div class="md:hidden"> | ||||||
|  |     <!-- Top Spacer --> | ||||||
|  |     <div class="h-6"></div> | ||||||
|  | 
 | ||||||
|  |     <div class="px-4 fixed flex items-center"> | ||||||
|  |       <!-- Hamburger Menu Button --> | ||||||
|  |       <button @click="toggleMobileMenu" | ||||||
|  |         class="text-D bg-C hover:bg-B transition-colors duration-200 p-0.5 rounded-sm z-50"> | ||||||
|  |         <svg :class="{ 'hidden': isMobileMenuOpen, 'block': !isMobileMenuOpen }" class="w-7 h-7" fill="none" | ||||||
|  |           stroke="currentColor" viewBox="0 0 24 24"> | ||||||
|  |           <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4 6h16M4 12h16M4 18h16" /> | ||||||
|  |         </svg> | ||||||
|  |         <svg :class="{ 'block': isMobileMenuOpen, 'hidden': !isMobileMenuOpen }" class="w-6 h-6" fill="none" | ||||||
|  |           stroke="currentColor" viewBox="0 0 24 24"> | ||||||
|  |           <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12" /> | ||||||
|  |         </svg> | ||||||
|  |       </button> | ||||||
|  |     </div> | ||||||
|  | 
 | ||||||
|  |     <!-- Mobile Menu --> | ||||||
|  |     <div :class="{ 'translate-x-0': isMobileMenuOpen, '-translate-x-full': !isMobileMenuOpen }" | ||||||
|  |       class="fixed inset-y-0 left-0 w-64 bg-A transform transition-transform duration-300 ease-in-out z-50 shadow-xl"> | ||||||
|  |       <!-- Mobile Menu Header --> | ||||||
|  |       <div class="px-4 py-3 flex justify-between items-center"> | ||||||
|  |         <img :src="logo" alt="Logo" class="h-8 w-auto" /> | ||||||
|  |         <button @click="closeMobileMenu" class="text-D hover:bg-B transition-colors duration-200"> | ||||||
|  |           <svg class="w-6 h-6" fill="none" stroke="currentColor" viewBox="0 0 24 24"> | ||||||
|  |             <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12" /> | ||||||
|  |           </svg> | ||||||
|  |         </button> | ||||||
|  |       </div> | ||||||
|  | 
 | ||||||
|  |       <!-- Mobile Menu Items --> | ||||||
|  |       <div class="py-4"> | ||||||
|  |         <!-- Kasir with Dropdown --> | ||||||
|  |         <div class="px-4 py-2"> | ||||||
|  |           <button @click="toggleDropdown" | ||||||
|  |             class="w-full flex justify-between items-center text-left text-lg text-D hover:bg-B rounded-md px-3 py-2 transition-colors duration-200"> | ||||||
|  |             {{ items[0].label }} | ||||||
|  |             <svg :class="{ 'rotate-180': isOpen }" class="w-4 h-4 transition-transform duration-200" fill="none" | ||||||
|  |               stroke="currentColor" viewBox="0 0 24 24"> | ||||||
|  |               <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19 9l-7 7-7-7" /> | ||||||
|  |             </svg> | ||||||
|  |           </button> | ||||||
|  | 
 | ||||||
|  |           <!-- Mobile Dropdown --> | ||||||
|  |           <div v-if="isOpen" class="mt-2 ml-4 space-y-1"> | ||||||
|  |             <router-link v-for="(sub, index) in items[0].subItems" :key="index" :to="sub.route" @click="closeMobileMenu" | ||||||
|  |               class="block px-3 py-2 text-D hover:bg-B rounded-md transition-colors duration-200"> | ||||||
|  |               {{ sub.label }} | ||||||
|  |             </router-link> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|  |         <!-- Other Menu Items --> | ||||||
|  |         <div class="px-4 space-y-1"> | ||||||
|  |           <template v-for="(item, index) in items.slice(1)" :key="index"> | ||||||
|  |             <router-link :to="item.route" @click="closeMobileMenu" | ||||||
|  |               class="block px-3 py-2 text-lg text-D hover:bg-B rounded-md transition-colors duration-200"> | ||||||
|  |               {{ item.label }} | ||||||
|  |             </router-link> | ||||||
|  |           </template> | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|  |         <!-- Logout --> | ||||||
|  |         <div class="fixed bottom-0 w-full px-4 py-3 bg-A border-t border-B"> | ||||||
|  |           <button @click="logout" | ||||||
|  |             class="block w-full text-left px-3 py-2 text-lg font-bold text-red-400 hover:text-white hover:bg-red-400 rounded-md transition-colors duration-200"> | ||||||
|  |             Logout | ||||||
|  |           </button> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  | 
 | ||||||
|  |     <!-- Mobile Menu Overlay --> | ||||||
|  |     <div v-if="isMobileMenuOpen" @click="closeMobileMenu" class="fixed inset-0 bg-black/75 z-40"></div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
							
								
								
									
										73
									
								
								resources/js/components/NavigationComponent.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								resources/js/components/NavigationComponent.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,73 @@ | |||||||
|  | <script setup> | ||||||
|  | import { ref, provide } from "vue"; | ||||||
|  | import NavDesktop from "./NavDesktop.vue"; | ||||||
|  | import NavMobile from "./NavMobile.vue"; | ||||||
|  | import logo from "../../images/logo.png"; | ||||||
|  | 
 | ||||||
|  | // Shared state | ||||||
|  | const isOpen = ref(false); | ||||||
|  | const isMobileMenuOpen = ref(false); | ||||||
|  | 
 | ||||||
|  | // Menu items configuration | ||||||
|  | const items = [ | ||||||
|  |   { label: "Manajemen Produk", subItems: [ | ||||||
|  |     { label: "Brankas", route: "/brankas" }, | ||||||
|  |     { label: "Nampan", route: "/nampan" }, | ||||||
|  |     { label: "Produk", route: "/produk" }, | ||||||
|  |     { label: "Kategori", route: "/kategori" }, | ||||||
|  |     { label: "Sales", route: "/sales" }, | ||||||
|  |   ] }, | ||||||
|  |   { label: "Kasir", route: "/kasir" }, | ||||||
|  |   { label: "Laporan", route: "/laporan" }, | ||||||
|  |   { label: "Akun", route: "/akun" }, | ||||||
|  | ]; | ||||||
|  | 
 | ||||||
|  | // Shared methods | ||||||
|  | const toggleDropdown = () => { | ||||||
|  |   isOpen.value = !isOpen.value; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | const toggleMobileMenu = () => { | ||||||
|  |   isMobileMenuOpen.value = !isMobileMenuOpen.value; | ||||||
|  |   isOpen.value = false; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | const closeMobileMenu = () => { | ||||||
|  |   isMobileMenuOpen.value = false; | ||||||
|  |   isOpen.value = false; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | const logout = () => { | ||||||
|  |   console.log("Logout clicked"); | ||||||
|  |   closeMobileMenu(); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | // Provide shared data to child components | ||||||
|  | provide('navigationData', { | ||||||
|  |   logo, | ||||||
|  |   items, | ||||||
|  |   isOpen, | ||||||
|  |   isMobileMenuOpen, | ||||||
|  |   toggleDropdown, | ||||||
|  |   toggleMobileMenu, | ||||||
|  |   closeMobileMenu, | ||||||
|  |   logout | ||||||
|  | }); | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <div class="relative"> | ||||||
|  |     <!-- Desktop Navigation --> | ||||||
|  |     <NavDesktop /> | ||||||
|  |      | ||||||
|  |     <!-- Mobile Navigation --> | ||||||
|  |     <NavMobile /> | ||||||
|  |      | ||||||
|  |     <!-- Click Outside Handler for Desktop Dropdown --> | ||||||
|  |     <div  | ||||||
|  |       v-if="isOpen && !isMobileMenuOpen" | ||||||
|  |       @click="isOpen = false" | ||||||
|  |       class="fixed inset-0 z-10" | ||||||
|  |     ></div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
| @ -1,15 +1,14 @@ | |||||||
| <template> | <template> | ||||||
|     <div  class="relative min-h-screen max-w-screen"> |   <div class="min-h-screen max-w-screen"> | ||||||
|         <Header /> |     <NavigationComponent /> | ||||||
|         <div class="mx-2 md:mx-4 lg:mx-6 xl:mx-7 my-6"> |     <div class="mx-2 md:mx-4 lg:mx-6 xl:mx-7 my-6"> | ||||||
|             <slot /> |       <slot /> | ||||||
|         </div> |  | ||||||
|         <Footer class="absolute bottom-0 w-full" /> |  | ||||||
| 
 |  | ||||||
|     </div> |     </div> | ||||||
|  |     <Footer class="bottom-0 w-full" /> | ||||||
|  |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import Header from '../components/Header.vue' |  | ||||||
| import Footer from '../components/Footer.vue' | import Footer from '../components/Footer.vue' | ||||||
|  | import NavigationComponent from '../components/NavigationComponent.vue'; | ||||||
| </script> | </script> | ||||||
| @ -51,7 +51,7 @@ | |||||||
|     <!-- Overlay Detail Produk --> |     <!-- Overlay Detail Produk --> | ||||||
|     <div |     <div | ||||||
|       v-if="showOverlay" |       v-if="showOverlay" | ||||||
|       class="fixed inset-0 bg-black/30 flex justify-center items-center z-50" |       class="fixed inset-0 bg-black/30 flex justify-center items-center" | ||||||
|       @click.self="closeOverlay" |       @click.self="closeOverlay" | ||||||
|     > |     > | ||||||
|       <div |       <div | ||||||
|  | |||||||
| @ -2,6 +2,7 @@ import { defineConfig } from 'vite'; | |||||||
| import laravel from 'laravel-vite-plugin'; | import laravel from 'laravel-vite-plugin'; | ||||||
| import tailwindcss from '@tailwindcss/vite'; | import tailwindcss from '@tailwindcss/vite'; | ||||||
| import vue from '@vitejs/plugin-vue'; | import vue from '@vitejs/plugin-vue'; | ||||||
|  | import vueDevTools from 'vite-plugin-vue-devtools' | ||||||
| 
 | 
 | ||||||
| export default defineConfig({ | export default defineConfig({ | ||||||
|     plugins: [ |     plugins: [ | ||||||
| @ -10,7 +11,8 @@ export default defineConfig({ | |||||||
|             refresh: true, |             refresh: true, | ||||||
|         }), |         }), | ||||||
|         tailwindcss(), |         tailwindcss(), | ||||||
|         vue() |         vue(), | ||||||
|  |         vueDevTools(), | ||||||
|     ], |     ], | ||||||
|     resolve: { |     resolve: { | ||||||
|         alias: { |         alias: { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user