form pernikahan prem
This commit is contained in:
		
							parent
							
								
									a89b5c2cb7
								
							
						
					
					
						commit
						3b42e905d3
					
				| @ -64,6 +64,7 @@ import GuestBook from '~/components/templates/Ultah/GuestBook.vue' | |||||||
| import ThankYou from '~/components/templates/Ultah/ThankYou.vue' | import ThankYou from '~/components/templates/Ultah/ThankYou.vue' | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| // Props dari halaman /p/[code].vue | // Props dari halaman /p/[code].vue | ||||||
| const props = defineProps({ | const props = defineProps({ | ||||||
|     data: { type: Object, required: true } |     data: { type: Object, required: true } | ||||||
|  | |||||||
| @ -8,136 +8,450 @@ | |||||||
|         Isi semua data berikut dengan lengkap dan benar. |         Isi semua data berikut dengan lengkap dan benar. | ||||||
|       </p> |       </p> | ||||||
| 
 | 
 | ||||||
|       <!-- Data Pemesan --> |  | ||||||
|       <section class="mb-8"> |       <section class="mb-8"> | ||||||
|         <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">📋 Data Pemesan</h2> |         <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">📋 Data Pemesan</h2> | ||||||
|         <div class="grid grid-cols-1 md:grid-cols-3 gap-4"> |         <div class="grid grid-cols-1 md:grid-cols-3 gap-4"> | ||||||
|           <input v-model="form.nama_pemesan" type="text" placeholder="Nama Pemesan" required | 
 | ||||||
|             class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |           <!-- Nama Pemesan --> | ||||||
|           <input v-model="form.email" type="email" placeholder="Email" required |           <div class="relative"> | ||||||
|             class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |             <input v-model="form.nama_pemesan" type="text" placeholder=" " required | ||||||
|           <input v-model="form.no_tlpn" type="text" placeholder="No Telepon" |               class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|             class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |             <label class="absolute left-1 top-0 text-gray-400 text-xs transition-all | ||||||
|  |                peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-gray-400 peer-placeholder-shown:text-sm | ||||||
|  |                peer-focus:top-0 peer-focus:left-1 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |               Nama Pemesan | ||||||
|  |             </label> | ||||||
|  |           </div> | ||||||
|  | 
 | ||||||
|  |           <!-- Email --> | ||||||
|  |           <div class="relative"> | ||||||
|  |             <input v-model="form.email" type="email" placeholder=" " required | ||||||
|  |               class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <label class="absolute left-1 top-0 text-gray-400 text-xs transition-all | ||||||
|  |                peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-gray-400 peer-placeholder-shown:text-sm | ||||||
|  |                peer-focus:top-0 peer-focus:left-1 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |               Email | ||||||
|  |             </label> | ||||||
|  |           </div> | ||||||
|  | 
 | ||||||
|  |           <!-- No Telepon --> | ||||||
|  |           <div class="relative"> | ||||||
|  |             <input v-model="form.no_tlpn" type="text" placeholder=" " required | ||||||
|  |               class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <label class="absolute left-1 top-0 text-gray-400 text-xs transition-all | ||||||
|  |                peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-gray-400 peer-placeholder-shown:text-sm | ||||||
|  |                peer-focus:top-0 peer-focus:left-1 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |               No Telepon | ||||||
|  |             </label> | ||||||
|  |           </div> | ||||||
|  | 
 | ||||||
|         </div> |         </div> | ||||||
|       </section> |       </section> | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|       <!-- Data Mempelai --> |       <!-- Data Mempelai --> | ||||||
|       <section class="mb-8"> |       <section class="mb-8"> | ||||||
|         <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">💍 Data Mempelai</h2> |         <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">💍 Data Mempelai</h2> | ||||||
|         <div class="grid grid-cols-1 md:grid-cols-2 gap-6"> |         <div class="grid grid-cols-1 md:grid-cols-2 gap-6"> | ||||||
|  | 
 | ||||||
|           <!-- Mempelai Pria --> |           <!-- Mempelai Pria --> | ||||||
|           <div> |           <div> | ||||||
|             <h3 class="font-medium text-gray-700 mb-2">Mempelai Pria</h3> |             <h3 class="font-medium text-gray-700 mb-2">Mempelai Pria</h3> | ||||||
|             <div class="grid gap-2"> |             <div class="space-y-3"> | ||||||
|               <input v-model="form.form.nama_lengkap_pria" placeholder="Nama Lengkap" | 
 | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |               <!-- Nama Lengkap --> | ||||||
|               <input v-model="form.form.nama_panggilan_pria" placeholder="Nama Panggilan" |               <div class="relative"> | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |                 <input v-model="form.form.nama_lengkap_pria" type="text" placeholder=" " required | ||||||
|               <input v-model="form.form.nama_bapak_pria" placeholder="Nama Bapak" |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|               <input v-model="form.form.nama_ibu_pria" placeholder="Nama Ibu" |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-blue-500 peer-focus:text-[10px] | ||||||
|               <input v-model="form.form.link_instagram_pria" placeholder="Link Instagram" |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |                   Nama Lengkap Pria | ||||||
|               <input v-model="form.form.link_facebook_pria" placeholder="Link Facebook" |                 </label> | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |               </div> | ||||||
|               <input v-model="form.form.link_twitter_pria" placeholder="Link Twitter" | 
 | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |               <!-- Nama Panggilan --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.nama_panggilan_pria" placeholder=" " required | ||||||
|  |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|  |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|  |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-blue-500 peer-focus:text-[10px] | ||||||
|  |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Nama Panggilan | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Nama Bapak --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.nama_bapak_pria" placeholder=" " required | ||||||
|  |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|  |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|  |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-blue-500 peer-focus:text-[10px] | ||||||
|  |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Nama Bapak | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Nama Ibu --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.nama_ibu_pria" placeholder=" " required | ||||||
|  |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|  |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|  |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-blue-500 peer-focus:text-[10px] | ||||||
|  |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Nama Ibu | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Link Instagram --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.link_instagram_pria" placeholder=" " required | ||||||
|  |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|  |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|  |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-blue-500 peer-focus:text-[10px] | ||||||
|  |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Link Instagram | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Link Facebook --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.link_facebook_pria" placeholder=" " required | ||||||
|  |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|  |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|  |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-blue-500 peer-focus:text-[10px] | ||||||
|  |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Link Facebook | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Link Twitter --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.link_twitter_pria" placeholder=" " required | ||||||
|  |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|  |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|  |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-blue-500 peer-focus:text-[10px] | ||||||
|  |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Link Twitter | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|           <!-- Mempelai Wanita --> |           <!-- Mempelai Wanita --> | ||||||
|           <div> |           <div> | ||||||
|             <h3 class="font-medium text-gray-700 mb-2">Mempelai Wanita</h3> |             <h3 class="font-medium text-gray-700 mb-2">Mempelai Wanita</h3> | ||||||
|             <div class="grid gap-2"> |             <div class="space-y-3"> | ||||||
|               <input v-model="form.form.nama_lengkap_wanita" placeholder="Nama Lengkap" | 
 | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> |               <!-- Nama Lengkap --> | ||||||
|               <input v-model="form.form.nama_panggilan_wanita" placeholder="Nama Panggilan" |               <div class="relative"> | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> |                 <input v-model="form.form.nama_lengkap_wanita" placeholder=" " required | ||||||
|               <input v-model="form.form.nama_bapak_wanita" placeholder="Nama Bapak" |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|               <input v-model="form.form.nama_ibu_wanita" placeholder="Nama Ibu" |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-pink-500 peer-focus:text-[10px] | ||||||
|               <input v-model="form.form.link_instagram_wanita" placeholder="Link Instagram" |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> |                   Nama Lengkap Wanita | ||||||
|               <input v-model="form.form.link_facebook_wanita" placeholder="Link Facebook" |                 </label> | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> |               </div> | ||||||
|               <input v-model="form.form.link_twitter_wanita" placeholder="Link Twitter" | 
 | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> |               <!-- Nama Panggilan --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.nama_panggilan_wanita" placeholder=" " required | ||||||
|  |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|  |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|  |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-pink-500 peer-focus:text-[10px] | ||||||
|  |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Nama pangilan | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Nama Bapak --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.nama_bapak_wanita" placeholder=" " required | ||||||
|  |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|  |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|  |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-pink-500 peer-focus:text-[10px] | ||||||
|  |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Nama Bapak | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Nama Ibu --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.nama_ibu_wanita" placeholder=" " required | ||||||
|  |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|  |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|  |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-pink-500 peer-focus:text-[10px] | ||||||
|  |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Nama Ibu | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Link Instagram --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.link_instagram_wanita" placeholder=" " required | ||||||
|  |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|  |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|  |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-pink-500 peer-focus:text-[10px] | ||||||
|  |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Link Instagram | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Link Facebook --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.link_facebook_wanita" placeholder=" " required | ||||||
|  |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|  |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|  |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-pink-500 peer-focus:text-[10px] | ||||||
|  |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Link Facebook | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Link Twitter --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.link_twitter_wanita" placeholder=" " required | ||||||
|  |                   class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm focus:ring-2 focus:ring-pink-400 focus:border-pink-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-1 text-gray-400 transition-all | ||||||
|  |                    peer-placeholder-shown:top-4 peer-placeholder-shown:left-2 peer-placeholder-shown:text-sm | ||||||
|  |                    peer-focus:top-0 peer-focus:left-1 peer-focus:text-pink-500 peer-focus:text-[10px] | ||||||
|  |                    peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Link Twitter | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|  | 
 | ||||||
|         </div> |         </div> | ||||||
|       </section> |       </section> | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|       <!-- Detail Acara --> |       <!-- Detail Acara --> | ||||||
|       <section class="mb-8"> |       <section class="mb-8"> | ||||||
|         <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">📅 Detail Acara</h2> |         <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">📅 Detail Acara</h2> | ||||||
|         <div class="grid grid-cols-1 md:grid-cols-2 gap-6"> |         <div class="grid grid-cols-1 md:grid-cols-2 gap-6"> | ||||||
|  | 
 | ||||||
|           <!-- Akad --> |           <!-- Akad --> | ||||||
|           <div> |           <div> | ||||||
|             <h3 class="font-medium text-gray-700 mb-2">Akad</h3> |             <h3 class="font-medium text-gray-700 mb-2">Akad</h3> | ||||||
|             <div class="grid gap-2"> |             <div class="space-y-3"> | ||||||
|               <input v-model="form.form.hari_tanggal_akad" type="date" placeholder="Hari & Tanggal Akad" | 
 | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |               <!-- Hari & Tanggal --> | ||||||
|               <input v-model="form.form.waktu_akad" type="time" placeholder="Waktu Akad" |               <div class="relative"> | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |                 <input v-model="form.form.hari_tanggal_akad" type="date" placeholder=" " class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|               <textarea v-model="form.form.alamat_akad" rows="3" placeholder="Alamat Akad" |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition resize-none"></textarea> |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|               <input v-model="form.form.link_gmaps_akad" type="text" placeholder="Link Google Maps Akad" |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Hari & Tanggal Akad | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Waktu Akad --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.waktu_akad" type="time" placeholder=" " class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|  |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Waktu Akad | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Alamat --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <textarea v-model="form.form.alamat_akad" rows="3" placeholder=" " required class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-5 pb-1.5 text-sm resize-none | ||||||
|  |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition"></textarea> | ||||||
|  |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Alamat Akad | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Link GMaps --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.link_gmaps_akad" type="text" placeholder=" " required class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|  |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Link Google Maps Akad | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|  | 
 | ||||||
|           <!-- Resepsi --> |           <!-- Resepsi --> | ||||||
|           <div> |           <div> | ||||||
|             <h3 class="font-medium text-gray-700 mb-2">Resepsi</h3> |             <h3 class="font-medium text-gray-700 mb-2">Resepsi</h3> | ||||||
|             <div class="grid gap-2"> |             <div class="space-y-3"> | ||||||
|               <input v-model="form.form.hari_tanggal_resepsi" type="date" placeholder="Hari & Tanggal Resepsi" | 
 | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |               <!-- Hari & Tanggal --> | ||||||
|               <input v-model="form.form.waktu_resepsi" type="time" placeholder="Waktu Resepsi" |               <div class="relative"> | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |                 <input v-model="form.form.hari_tanggal_resepsi" type="date" placeholder=" " class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|               <textarea v-model="form.form.alamat_resepsi" rows="3" placeholder="Alamat Resepsi" |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition resize-none"></textarea> |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|               <input v-model="form.form.link_gmaps_resepsi" type="text" placeholder="Link Google Maps Resepsi" |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Hari & Tanggal Resepsi | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Waktu --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.waktu_resepsi" type="time" placeholder=" " class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|  |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Waktu Resepsi | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Alamat --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <textarea v-model="form.form.alamat_resepsi" rows="3" placeholder=" " required class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-5 pb-1.5 text-sm resize-none | ||||||
|  |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition"></textarea> | ||||||
|  |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Alamat Resepsi | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Link GMaps --> | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.link_gmaps_resepsi" type="text" placeholder=" " required class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|  |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Link Google Maps Resepsi | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|  | 
 | ||||||
|           <!-- Syukuran --> |           <!-- Syukuran --> | ||||||
|           <div> |           <div> | ||||||
|             <h3 class="font-medium text-gray-700 mb-2">Syukuran</h3> |             <h3 class="font-medium text-gray-700 mb-2">Syukuran</h3> | ||||||
|             <div class="grid gap-2"> |             <div class="space-y-3"> | ||||||
|               <input v-model="form.form.hari_tanggal_syukuran" type="date" placeholder="Hari & Tanggal Syukuran" | 
 | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |               <div class="relative"> | ||||||
|               <input v-model="form.form.waktu_syukuran" type="time" placeholder="Waktu Syukuran" |                 <input v-model="form.form.hari_tanggal_syukuran" type="date" placeholder=" " class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|               <textarea v-model="form.form.alamat_syukuran" rows="3" placeholder="Alamat Syukuran" |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition resize-none"></textarea> |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|               <input v-model="form.form.link_gmaps_syukuran" type="text" placeholder="Link Google Maps Syukuran" |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|                 class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Hari & Tanggal Syukuran | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.waktu_syukuran" type="time" placeholder=" " class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|  |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Waktu Syukuran | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <textarea v-model="form.form.alamat_syukuran" rows="3" placeholder=" " required class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-5 pb-1.5 text-sm resize-none | ||||||
|  |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition"></textarea> | ||||||
|  |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Alamat Syukuran | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <div class="relative"> | ||||||
|  |                 <input v-model="form.form.link_gmaps_syukuran" type="text" placeholder=" " required class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|  |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Link Google Maps Syukuran | ||||||
|  |                 </label> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|  | 
 | ||||||
|           <!-- Hitung Mundur --> |           <!-- Hitung Mundur --> | ||||||
|           <div> |           <div> | ||||||
|             <h3 class="font-medium text-gray-700 mb-3">Hitung Mundur</h3> |             <h3 class="font-medium text-gray-700 mb-3">Hitung Mundur</h3> | ||||||
|             <div class="grid grid-cols-1 md:grid-cols-2 gap-4"> |             <div class="grid grid-cols-1 md:grid-cols-2 gap-4"> | ||||||
|               <!-- Mulai --> | 
 | ||||||
|               <div> |               <div class="relative"> | ||||||
|                 <label class="block text-gray-600 text-sm mb-1">Mulai dari</label> |                 <input v-model="form.form.hitung_mundur_mulai" type="datetime-local" placeholder=" " class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|                 <input v-model="form.form.hitung_mundur_mulai" type="datetime-local" |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Mulai Dari | ||||||
|  |                 </label> | ||||||
|               </div> |               </div> | ||||||
| 
 | 
 | ||||||
|               <!-- Sampai --> |               <div class="relative"> | ||||||
|               <div> |                 <input v-model="form.form.hitung_mundur_selesai" type="datetime-local" placeholder=" " class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|                 <label class="block text-gray-600 text-sm mb-1">Sampai dengan</label> |                    focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|                 <input v-model="form.form.hitung_mundur_selesai" type="datetime-local" |                 <label class="absolute left-2 text-gray-400 transition-all | ||||||
|                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |                  peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                  peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                  peer-valid:top-0 peer-valid:left-1 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |                   Sampai Dengan | ||||||
|  |                 </label> | ||||||
|               </div> |               </div> | ||||||
|  | 
 | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|         </div> |         </div> | ||||||
|       </section> |       </section> | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|       <!-- Cerita Kita --> |       <!-- Cerita Kita --> | ||||||
|       <section class="mb-8"> |       <section class="mb-8"> | ||||||
|         <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">💌 Cerita Kita</h2> |         <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">💌 Cerita Kita</h2> | ||||||
| @ -155,20 +469,81 @@ | |||||||
|       <!-- Rekening & Musik --> |       <!-- Rekening & Musik --> | ||||||
|       <section class="mb-8"> |       <section class="mb-8"> | ||||||
|         <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">💳 Rekening & Musik</h2> |         <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">💳 Rekening & Musik</h2> | ||||||
|         <div class="grid md:grid-cols-3 gap-4"> | 
 | ||||||
|           <input v-model="form.form.rekening_1" placeholder="Rekening 1" |         <!-- Rekening --> | ||||||
|             class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |         <div class="grid grid-cols-1 md:grid-cols-3 gap-6 mb-6"> | ||||||
|           <input v-model="form.form.rekening_2" placeholder="Rekening 2" |           <!-- Rekening 1 --> | ||||||
|             class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |           <div class="relative"> | ||||||
|           <input v-model="form.form.rekening_3" placeholder="Rekening 3" |             <input v-model="form.form.rekening_1" type="text" placeholder=" " required  | ||||||
|             class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |             class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|  |                focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |               Rekening 1 | ||||||
|  |             </label> | ||||||
|  |           </div> | ||||||
|  | 
 | ||||||
|  |           <!-- Rekening 2 --> | ||||||
|  |           <div class="relative"> | ||||||
|  |             <input v-model="form.form.rekening_2" type="text" placeholder=" " required | ||||||
|  |              class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|  |                focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |               Rekening 2 | ||||||
|  |             </label> | ||||||
|  |           </div> | ||||||
|  | 
 | ||||||
|  |           <!-- Rekening 3 --> | ||||||
|  |           <div class="relative"> | ||||||
|  |             <input v-model="form.form.rekening_3" type="text" placeholder=" " required | ||||||
|  |              class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|  |                focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |               Rekening 3 | ||||||
|  |             </label> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|  |         <!-- Musik & Live Streaming --> | ||||||
|  |         <div class="grid grid-cols-1 md:grid-cols-2 gap-6"> | ||||||
|  |           <!-- Link Music --> | ||||||
|  |           <div class="relative"> | ||||||
|  |             <input v-model="form.form.link_music" type="text" placeholder=" " required | ||||||
|  |             class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|  |                focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |               Link Music | ||||||
|  |             </label> | ||||||
|  |           </div> | ||||||
|  | 
 | ||||||
|  |           <!-- Link Live Streaming --> | ||||||
|  |           <div class="relative"> | ||||||
|  |             <input v-model="form.form.link_live_streaming" type="text"  placeholder=" " required  | ||||||
|  |              class="peer w-full border border-gray-300 rounded-lg px-2.5 pt-4 pb-1.5 text-sm  | ||||||
|  |                focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <label class="absolute left-2 text-gray-400 transition-all | ||||||
|  |                peer-placeholder-shown:top-4 peer-placeholder-shown:text-sm | ||||||
|  |                peer-focus:top-0 peer-focus:text-[10px] peer-focus:text-blue-500 | ||||||
|  |                peer-valid:top-0 peer-valid:text-[10px] peer-valid:text-gray-500"> | ||||||
|  |               Link Live Streaming | ||||||
|  |             </label> | ||||||
|  |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <input v-model="form.form.link_music" placeholder="Link Music (opsional)" |  | ||||||
|           class="w-full border border-gray-300 rounded-lg px-3 py-2 mt-4 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |  | ||||||
|         <input v-model="form.form.link_live_streaming" placeholder="Link Live Streaming (opsional)" |  | ||||||
|           class="w-full border border-gray-300 rounded-lg px-3 py-2 mt-4 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> |  | ||||||
|       </section> |       </section> | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|       <!-- Foto Upload --> |       <!-- Foto Upload --> | ||||||
|       <section class="mb-8"> |       <section class="mb-8"> | ||||||
|         <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">🖼️ Galeri Foto</h2> |         <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">🖼️ Galeri Foto</h2> | ||||||
| @ -347,7 +722,7 @@ const konfirmasi = async () => { | |||||||
|       throw new Error(msg) |       throw new Error(msg) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| await Swal.fire({ |     await Swal.fire({ | ||||||
|       title: '🎉 Berhasil!', |       title: '🎉 Berhasil!', | ||||||
|       text: result.message || 'Data undangan kamu berhasil disimpan.', |       text: result.message || 'Data undangan kamu berhasil disimpan.', | ||||||
|       icon: 'success', |       icon: 'success', | ||||||
|  | |||||||
							
								
								
									
										356
									
								
								proyek-frontend/app/pages/form/undangan-ulang-tahun-premium.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										356
									
								
								proyek-frontend/app/pages/form/undangan-ulang-tahun-premium.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,356 @@ | |||||||
|  | <template> | ||||||
|  |     <div class="min-h-screen bg-gray-50 py-10 px-6"> | ||||||
|  |       <div class="max-w-5xl mx-auto bg-white rounded-2xl shadow-lg p-8"> | ||||||
|  |         <h1 class="text-2xl font-bold text-center text-gray-800"> | ||||||
|  |           Form Undangan Ulang Tahun Premium | ||||||
|  |         </h1> | ||||||
|  |         <p class="text-center text-gray-500 text-sm mb-8"> | ||||||
|  |           Isi semua data berikut dengan lengkap dan benar. | ||||||
|  |         </p> | ||||||
|  | 
 | ||||||
|  |         <!-- Data Pemesan --> | ||||||
|  |         <section class="mb-8"> | ||||||
|  |           <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">📋 Data Pemesan</h2> | ||||||
|  |           <div class="grid grid-cols-1 md:grid-cols-3 gap-4"> | ||||||
|  |             <input v-model="form.nama_pemesan" type="text" placeholder="Nama Pemesan" | ||||||
|  |               class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <input v-model="form.email" type="email" placeholder="Email" | ||||||
|  |               class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <input v-model="form.no_tlpn" type="text" placeholder="No Telepon" | ||||||
|  |               class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |           </div> | ||||||
|  |         </section> | ||||||
|  | 
 | ||||||
|  |         <!-- Data Anak --> | ||||||
|  |         <section class="mb-8"> | ||||||
|  |           <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">🎉 Data Anak</h2> | ||||||
|  |           <div class="grid grid-cols-1 md:grid-cols-2 gap-6"> | ||||||
|  |             <div> | ||||||
|  |               <div class="grid gap-2"> | ||||||
|  |                 <input v-model="form.form.nama_lengkap" placeholder="Nama Lengkap" | ||||||
|  |                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <input v-model="form.form.nama_panggilan" placeholder="Nama Panggilan" | ||||||
|  |                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <input v-model="form.form.nama_bapak" placeholder="Nama Bapak" | ||||||
|  |                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <input v-model="form.form.nama_ibu" placeholder="Nama Ibu" | ||||||
|  |                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <input v-model="form.form.umur_yang_dirayakan" type="number" placeholder="Umur Yang Dirayakan" | ||||||
|  |                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <input v-model="form.form.anak_ke" type="number" placeholder="Anak Ke" | ||||||
|  |                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |               </div> | ||||||
|  |             </div> | ||||||
|  |             <div> | ||||||
|  |               <div class="grid gap-2"> | ||||||
|  |                 <input v-model="form.form.instagram" placeholder="Link Instagram" | ||||||
|  |                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <input v-model="form.form.facebook" placeholder="Link Facebook" | ||||||
|  |                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |                 <input v-model="form.form.twitter" placeholder="Link Twitter" | ||||||
|  |                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |               </div> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |         </section> | ||||||
|  | 
 | ||||||
|  |         <!-- Detail Acara --> | ||||||
|  |         <section class="mb-8"> | ||||||
|  |           <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">📅 Detail Acara</h2> | ||||||
|  |           <div class="grid grid-cols-1 md:grid-cols-2 gap-4"> | ||||||
|  |             <input v-model="form.form.hari_tanggal_acara" type="date" placeholder="Hari & Tanggal Acara" | ||||||
|  |               class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <input v-model="form.form.waktu" type="text" placeholder="Waktu" | ||||||
|  |               class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <textarea v-model="form.form.alamat" rows="4" placeholder="Alamat" | ||||||
|  |               class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition resize-none"></textarea> | ||||||
|  |             <input v-model="form.form.link_gmaps" type="text" placeholder="Link Gmaps" | ||||||
|  |               class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <!-- Hitung Mundur --> | ||||||
|  |           <div> | ||||||
|  |             <h3 class="font-medium text-gray-700 mb-3">Hitung Mundur</h3> | ||||||
|  |             <div class="grid grid-cols-1 md:grid-cols-2 gap-4"> | ||||||
|  |               <!-- Mulai --> | ||||||
|  |               <div> | ||||||
|  |                 <label class="block text-gray-600 text-sm mb-1">Mulai dari</label> | ||||||
|  |                 <input v-model="form.form.hitung_mundur_mulai" type="datetime-local" | ||||||
|  |                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- Sampai --> | ||||||
|  |               <div> | ||||||
|  |                 <label class="block text-gray-600 text-sm mb-1">Sampai dengan</label> | ||||||
|  |                 <input v-model="form.form.hitung_mundur_selesai" type="datetime-local" | ||||||
|  |                   class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |               </div> | ||||||
|  |             <input v-model="form.form.link_live_streaming" type="text" placeholder="Link Live Streaming" | ||||||
|  |               class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |           </div> | ||||||
|  |           </div> | ||||||
|  |           </div> | ||||||
|  |            | ||||||
|  |         </section> | ||||||
|  | 
 | ||||||
|  |         <!-- Pesan & Rekening --> | ||||||
|  |         <section class="mb-8"> | ||||||
|  |           <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">💌 Pesan & Rekening</h2> | ||||||
|  |           <textarea v-model="form.form.say_something" rows="4" placeholder="Say Something..." | ||||||
|  |             class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition resize-none"></textarea> | ||||||
|  |           <div class="grid md:grid-cols-3 gap-4 mt-4"> | ||||||
|  |             <input v-model="form.form.rekening_1" placeholder="Rekening 1" | ||||||
|  |               class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <input v-model="form.form.rekening_2" placeholder="Rekening 2" | ||||||
|  |               class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |             <input v-model="form.form.rekening_3" placeholder="Rekening 3" | ||||||
|  |               class="w-full border border-gray-300 rounded-lg px-3 py-2 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |           </div> | ||||||
|  |           <input v-model="form.form.link_music" placeholder="Link Music (opsional)" | ||||||
|  |             class="w-full border border-gray-300 rounded-lg px-3 py-2 mt-4 focus:ring-2 focus:ring-blue-400 focus:border-blue-400 outline-none transition" /> | ||||||
|  |         </section> | ||||||
|  | 
 | ||||||
|  |         <!-- Foto Upload --> | ||||||
|  |         <section class="mb-8"> | ||||||
|  |           <h2 class="font-semibold text-blue-600 mb-3 border-b pb-1">🖼️ Galeri Foto</h2> | ||||||
|  |           <div | ||||||
|  |             class="border-2 border-dashed border-gray-300 rounded-xl p-8 flex flex-col justify-center items-center text-gray-400 hover:border-blue-400 hover:text-blue-500 transition" | ||||||
|  |           > | ||||||
|  |             <input | ||||||
|  |               id="gallery" | ||||||
|  |               type="file" | ||||||
|  |               multiple | ||||||
|  |               accept="image/*" | ||||||
|  |               class="hidden" | ||||||
|  |               @change="handleFileChange" | ||||||
|  |             /> | ||||||
|  |             <label v-if="!previews.length" for="gallery" class="cursor-pointer flex flex-col items-center"> | ||||||
|  |               <span class="text-4xl font-bold">+</span> | ||||||
|  |               <span class="text-sm mt-2">Pilih Foto (maks. 8, JPEG/PNG, maks. 2MB)</span> | ||||||
|  |             </label> | ||||||
|  |             <div v-else class="grid grid-cols-3 sm:grid-cols-4 gap-4"> | ||||||
|  |               <div | ||||||
|  |                 v-for="(src, i) in previews" | ||||||
|  |                 :key="i" | ||||||
|  |                 class="relative group" | ||||||
|  |               > | ||||||
|  |                 <img | ||||||
|  |                   :src="src" | ||||||
|  |                   class="w-24 h-24 object-cover rounded-lg border shadow" | ||||||
|  |                 /> | ||||||
|  |                 <button | ||||||
|  |                   @click="removeFile(i)" | ||||||
|  |                   class="absolute -top-2 -right-2 bg-red-500 text-white rounded-full w-5 h-5 flex items-center justify-center text-xs opacity-0 group-hover:opacity-100 transition" | ||||||
|  |                   title="Hapus foto" | ||||||
|  |                 > | ||||||
|  |                   ✕ | ||||||
|  |                 </button> | ||||||
|  |               </div> | ||||||
|  |               <label | ||||||
|  |                 v-if="previews.length < 8" | ||||||
|  |                 for="gallery" | ||||||
|  |                 class="cursor-pointer flex flex-col items-center justify-center w-24 h-24 border-2 border-dashed border-gray-300 rounded-lg text-gray-400 hover:border-blue-400 hover:text-blue-500 transition" | ||||||
|  |               > | ||||||
|  |                 <span class="text-3xl font-bold">+</span> | ||||||
|  |               </label> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |         </section> | ||||||
|  | 
 | ||||||
|  |         <!-- Tombol --> | ||||||
|  |         <div class="text-end mt-6"> | ||||||
|  |           <button @click="batal" | ||||||
|  |             class="bg-gray-600 text-white font-semibold px-6 py-2 rounded-lg transition mr-2"> | ||||||
|  |             Batal | ||||||
|  |           </button> | ||||||
|  |           <button @click="konfirmasi" | ||||||
|  |             class="bg-blue-700 text-white font-semibold px-6 py-2 rounded-lg transition"> | ||||||
|  |             Konfirmasi | ||||||
|  |           </button> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script setup> | ||||||
|  | import { ref } from 'vue' | ||||||
|  | import { useRouter } from 'vue-router' | ||||||
|  | import Swal from 'sweetalert2' | ||||||
|  | 
 | ||||||
|  | const router = useRouter() | ||||||
|  | const ADMIN_WA = '62895333053398' | ||||||
|  | 
 | ||||||
|  | const form = ref({ | ||||||
|  |   nama_pemesan: '', | ||||||
|  |   email: '', | ||||||
|  |   no_tlpn: '', | ||||||
|  |   form: { | ||||||
|  |     nama_lengkap: '', | ||||||
|  |     nama_panggilan: '', | ||||||
|  |     nama_bapak: '', | ||||||
|  |     nama_ibu: '', | ||||||
|  |     umur_yang_dirayakan: '', | ||||||
|  |     anak_ke: '', | ||||||
|  |     instagram: '', | ||||||
|  |     facebook: '', | ||||||
|  |     twitter: '', | ||||||
|  |     hari_tanggal_acara: '', | ||||||
|  |     waktu: '', | ||||||
|  |     alamat: '', | ||||||
|  |     link_gmaps: '', | ||||||
|  |     hitung_mundur_mulai: '', | ||||||
|  |     hitung_mundur_selesai: '', | ||||||
|  |     link_live_streaming: '', | ||||||
|  |     say_something: '', | ||||||
|  |     rekening_1: '', | ||||||
|  |     rekening_2: '', | ||||||
|  |     rekening_3: '', | ||||||
|  |     link_music: '' | ||||||
|  |   }, | ||||||
|  |   foto: [] | ||||||
|  | }) | ||||||
|  | 
 | ||||||
|  | const previews = ref([]) | ||||||
|  | 
 | ||||||
|  | const handleFileChange = (e) => { | ||||||
|  |   const files = Array.from(e.target.files) | ||||||
|  |   const totalFiles = form.value.foto.length + files.length | ||||||
|  | 
 | ||||||
|  |   if (totalFiles > 8) { | ||||||
|  |     alert('Maksimal 8 foto!') | ||||||
|  |     e.target.value = '' | ||||||
|  |     return | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   files.forEach(file => { | ||||||
|  |     if (file.size > 2 * 1024 * 1024) { | ||||||
|  |       alert(`File ${file.name} terlalu besar! Maksimal 2MB.`) | ||||||
|  |       return | ||||||
|  |     } | ||||||
|  |     if (!['image/jpeg', 'image/png', 'image/jpg'].includes(file.type)) { | ||||||
|  |       alert(`File ${file.name} harus berupa JPEG atau PNG!`) | ||||||
|  |       return | ||||||
|  |     } | ||||||
|  |     form.value.foto.push(file) | ||||||
|  |     previews.value.push(URL.createObjectURL(file)) | ||||||
|  |   }) | ||||||
|  |   e.target.value = '' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const removeFile = (index) => { | ||||||
|  |   form.value.foto.splice(index, 1) | ||||||
|  |   previews.value.splice(index, 1) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const konfirmasi = async () => { | ||||||
|  |   try { | ||||||
|  |     if (!form.value.nama_pemesan || !form.value.email) { | ||||||
|  |       alert('Harap isi kolom wajib (Nama Pemesan, Email)!') | ||||||
|  |       return | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     const data = new FormData() | ||||||
|  |     data.append('nama_pemesan', form.value.nama_pemesan) | ||||||
|  |     data.append('email', form.value.email) | ||||||
|  |     data.append('no_tlpn', form.value.no_tlpn) | ||||||
|  |     data.append('template_slug', 'undangan-ulang-tahun-premium') | ||||||
|  | 
 | ||||||
|  |     for (const [key, value] of Object.entries(form.value.form)) { | ||||||
|  |       data.append(`form[${key}]`, value) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     form.value.foto.forEach((file, index) => { | ||||||
|  |       data.append(`foto[${index}]`, file) | ||||||
|  |     }) | ||||||
|  | 
 | ||||||
|  |     const res = await fetch('http://localhost:8000/api/pelanggans', { | ||||||
|  |       method: 'POST', | ||||||
|  |       body: data | ||||||
|  |     }) | ||||||
|  | 
 | ||||||
|  |     const result = await res.json() | ||||||
|  | 
 | ||||||
|  |     if (!res.ok) { | ||||||
|  |       if (res.status === 422) { | ||||||
|  |         const errors = result.errors || {} | ||||||
|  |         const errorMessages = Object.values(errors).flat().join('\n') | ||||||
|  |         throw new Error(errorMessages || result.message || 'Validasi gagal') | ||||||
|  |       } | ||||||
|  |       if (res.status === 404) { | ||||||
|  |         throw new Error(result.message || 'Template tidak ditemukan') | ||||||
|  |       } | ||||||
|  |       throw new Error(result.message || 'Gagal mengirim data') | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     await Swal.fire({ | ||||||
|  |       title: '🎉 Berhasil!', | ||||||
|  |       text: result.message || 'Data undangan kamu berhasil disimpan.', | ||||||
|  |       icon: 'success', | ||||||
|  |       confirmButtonText: 'Lanjut ke WhatsApp', | ||||||
|  |       confirmButtonColor: '#2563eb', | ||||||
|  |       background: '#f9fafb', | ||||||
|  |       color: '#111827', | ||||||
|  |       showClass: { | ||||||
|  |         popup: 'animate__animated animate__fadeInDown' | ||||||
|  |       }, | ||||||
|  |       hideClass: { | ||||||
|  |         popup: 'animate__animated animate__fadeOutUp' | ||||||
|  |       } | ||||||
|  |     }) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |      | ||||||
|  |     const f = form.value | ||||||
|  |     const child = f.form | ||||||
|  | 
 | ||||||
|  |     const message = ` | ||||||
|  | Halo Admin 👋, | ||||||
|  | Saya ingin membuat *Undangan Ulang Tahun Premium* 🎂 | ||||||
|  | 
 | ||||||
|  | 📋 *Data Pemesan* | ||||||
|  | - Nama: ${f.nama_pemesan} | ||||||
|  | - Email: ${f.email} | ||||||
|  | - No. Telepon: ${f.no_tlpn} | ||||||
|  | 
 | ||||||
|  | 🎉 *Data Anak* | ||||||
|  | - Nama Lengkap: ${child.nama_lengkap} | ||||||
|  | - Nama Panggilan: ${child.nama_panggilan} | ||||||
|  | - Umur: ${child.umur_yang_dirayakan} tahun | ||||||
|  | - Anak ke: ${child.anak_ke} | ||||||
|  | - Bapak: ${child.nama_bapak} | ||||||
|  | - Ibu: ${child.nama_ibu} | ||||||
|  | 
 | ||||||
|  | 📅 *Detail Acara* | ||||||
|  | - Tanggal: ${child.hari_tanggal_acara} | ||||||
|  | - Waktu: ${child.waktu} | ||||||
|  | - Alamat: ${child.alamat} | ||||||
|  | - Link Gmaps: ${child.link_gmaps || '-'} | ||||||
|  | 
 | ||||||
|  | 💌 *Pesan Tambahan* | ||||||
|  | ${child.say_something || '-'} | ||||||
|  | 
 | ||||||
|  | Terima kasih 🙏 | ||||||
|  | ` | ||||||
|  | 
 | ||||||
|  |     const encodedMsg = encodeURIComponent(message) | ||||||
|  |     const waUrl = `https://wa.me/${ADMIN_WA}?text=${encodedMsg}` | ||||||
|  | 
 | ||||||
|  |     Swal.fire({ | ||||||
|  |       title: 'Membuka WhatsApp...', | ||||||
|  |       text: 'Mohon tunggu sebentar ⏳', | ||||||
|  |       timer: 1500, | ||||||
|  |       timerProgressBar: true, | ||||||
|  |       showConfirmButton: false, | ||||||
|  |       willClose: () => { | ||||||
|  |         window.open(waUrl, '_blank') | ||||||
|  |         router.push('/') | ||||||
|  |       } | ||||||
|  |     }) | ||||||
|  |   } catch (err) { | ||||||
|  |     Swal.fire('❌ Gagal', err.message, 'error') | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | const batal = () => router.back() | ||||||
|  | </script> | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user