<div class="w-full px-4 py-8"> <% if notice.present? %> <div class="mb-6"> <p class="py-3 px-4 bg-green-50 text-green-800 font-medium rounded-lg inline-flex items-center" id="notice"> <svg class="w-5 h-5 mr-2" fill="currentColor" viewBox="0 0 20 20"> <path fill-rule="evenodd" d="M10 18a8 8 0 100-16 8 8 0 000 16zm3.707-9.293a1 1 0 00-1.414-1.414L9 10.586 7.707 9.293a1 1 0 00-1.414 1.414l2 2a1 1 0 001.414 0l4-4z" clip-rule="evenodd"/> </svg> <%= notice %> </p> </div> <% end %> <div class="flex flex-col sm:flex-row sm:justify-between sm:items-center mb-8 gap-4"> <div> <h1 class="font-bold text-3xl sm:text-4xl text-gray-900">Credit Card Bills</h1> <p class="mt-2 text-sm text-gray-600">Track and manage your credit card expenses and member burdens</p> </div> <%= link_to new_credit_card_bill_path, class: "rounded-lg py-2.5 px-4 sm:py-3 sm:px-5 bg-blue-600 hover:bg-blue-700 text-white font-medium transition-colors inline-flex items-center justify-center sm:justify-start" do %> <svg class="w-5 h-5 mr-2" fill="none" stroke="currentColor" viewBox="0 0 24 24"> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 4v16m8-8H4"/> </svg> New credit card bill <% end %> </div> <% if @credit_card_bills.any? %> <!-- Summary Cards --> <div class="grid grid-cols-1 md:grid-cols-3 gap-6 mb-8"> <div class="bg-white rounded-lg shadow p-6"> <div class="flex items-center"> <div class="flex-shrink-0"> <svg class="h-8 w-8 text-blue-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M3 10h18M7 15h1m4 0h1m-7 4h12a3 3 0 003-3V8a3 3 0 00-3-3H6a3 3 0 00-3 3v8a3 3 0 003 3z"/> </svg> </div> <div class="ml-4"> <p class="text-sm font-medium text-gray-500">Total Bills</p> <p class="text-2xl font-semibold text-gray-900"><%= @credit_card_bills.count %></p> </div> </div> </div> <div class="bg-white rounded-lg shadow p-6"> <div class="flex items-center"> <div class="flex-shrink-0"> <svg class="h-8 w-8 text-green-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 8c-1.657 0-3 .895-3 2s1.343 2 3 2 3 .895 3 2-1.343 2-3 2m0-8c1.11 0 2.08.402 2.599 1M12 8V7m0 1v8m0 0v1m0-1c-1.11 0-2.08-.402-2.599-1"/> </svg> </div> <div class="ml-4"> <p class="text-sm font-medium text-gray-500">Total Amount</p> <p class="text-2xl font-semibold text-gray-900"><%= number_to_currency(@credit_card_bills.sum(:amount)) %></p> </div> </div> </div> <div class="bg-white rounded-lg shadow p-6"> <div class="flex items-center"> <div class="flex-shrink-0"> <svg class="h-8 w-8 text-red-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 8v4m0 4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"/> </svg> </div> <div class="ml-4"> <p class="text-sm font-medium text-gray-500">Unbudgeted</p> <p class="text-2xl font-semibold text-gray-900"><%= number_to_currency(@credit_card_bills.sum(&:unpaid)) %></p> </div> </div> </div> </div> <!-- Desktop Table View --> <div class="hidden lg:block overflow-x-auto bg-white rounded-lg shadow"> <table class="min-w-full"> <thead class="bg-gray-50 border-b border-gray-200"> <tr> <th scope="col" class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">Description</th> <th scope="col" class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">Total Amount</th> <th scope="col" class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">Unbudgeted</th> <th scope="col" class="px-6 py-3 text-right text-xs font-medium text-gray-500 uppercase tracking-wider">Actions</th> </tr> </thead> <tbody class="bg-white divide-y divide-gray-200"> <% @credit_card_bills.each do |bill| %> <tr class="hover:bg-gray-50 transition-colors"> <td class="px-6 py-4 whitespace-nowrap"> <div class="text-sm font-medium text-gray-900"><%= bill.description %></div> </td> <td class="px-6 py-4 whitespace-nowrap"> <span class="text-sm text-gray-900 font-mono"><%= number_to_currency(bill.amount) %></span> </td> <td class="px-6 py-4 whitespace-nowrap"> <span class="text-sm text-gray-900 font-mono"><%= number_to_currency(bill.unpaid) %></span> </td> <td class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium"> <%= link_to "View", bill, class: "text-blue-600 hover:text-blue-900 mr-3" %> <%= link_to "Edit", edit_credit_card_bill_path(bill), class: "text-indigo-600 hover:text-indigo-900" %> </td> </tr> <% end %> </tbody> </table> </div> <!-- Mobile Card View --> <div class="lg:hidden space-y-4"> <% @credit_card_bills.each do |bill| %> <div class="bg-white rounded-lg shadow p-4 hover:shadow-md transition-shadow"> <div class="flex justify-between items-start mb-3"> <h3 class="text-lg font-medium text-gray-900"><%= bill.description %></h3> <div class="flex gap-2"> <%= link_to bill, class: "text-blue-600 hover:text-blue-800" do %> <svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24"> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M15 12a3 3 0 11-6 0 3 3 0 016 0z"/> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"/> </svg> <% end %> <%= link_to edit_credit_card_bill_path(bill), class: "text-indigo-600 hover:text-indigo-800" do %> <svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24"> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M11 5H6a2 2 0 00-2 2v11a2 2 0 002 2h11a2 2 0 002-2v-5m-1.414-9.414a2 2 0 112.828 2.828L11.828 15H9v-2.828l8.586-8.586z"/> </svg> <% end %> </div> </div> <div class="grid grid-cols-2 gap-3"> <div class="flex justify-between items-center"> <span class="text-sm text-gray-500">Total Amount</span> <span class="text-sm font-mono font-medium"><%= number_to_currency(bill.amount) %></span> </div> <div class="flex justify-between items-center"> <span class="text-sm text-gray-500">Unbudgeted</span> <span class="text-sm font-mono font-medium text-gray-900"><%= number_to_currency(bill.unpaid) %></span> </div> </div> </div> <% end %> </div> <% else %> <div class="text-center py-12 bg-white rounded-lg shadow"> <svg class="mx-auto h-12 w-12 text-gray-400" fill="none" stroke="currentColor" viewBox="0 0 24 24"> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M3 10h18M7 15h1m4 0h1m-7 4h12a3 3 0 003-3V8a3 3 0 00-3-3H6a3 3 0 00-3 3v8a3 3 0 003 3z"/> </svg> <h3 class="mt-2 text-sm font-medium text-gray-900">No credit card bills</h3> <p class="mt-1 text-sm text-gray-500">Get started by creating a new credit card bill.</p> <div class="mt-6"> <%= link_to new_credit_card_bill_path, class: "inline-flex items-center px-4 py-2 border border-transparent shadow-sm text-sm font-medium rounded-md text-white bg-blue-600 hover:bg-blue-700" do %> <svg class="w-5 h-5 mr-2" fill="none" stroke="currentColor" viewBox="0 0 24 24"> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 4v16m8-8H4"/> </svg> New credit card bill <% end %> </div> </div> <% end %> </div>