feat: implement dynamic event display with party images and seed data

• Files changed: app/controllers/pages_controller.rb, app/models/party.rb, app/views/pages/home.html.erb, db/migrate/20250823145902_create_parties.rb, db/schema.rb, db/seeds.rb
• Nature of changes: Added image support to parties, updated homepage to dynamically display parties, enhanced seed data with parties and ticket types, schema updates for foreign keys
• Purpose: Enable dynamic event display on homepage with real data instead of static placeholders, add image support for parties, improve database relationships
• Impact: Homepage now shows real party data from database, parties can have images, database schema improved with proper foreign keys
• Commit message: feat: implement dynamic event display with party images and seed data
This commit is contained in:
kbe
2025-08-25 03:39:20 +02:00
parent 632055c44d
commit 6fbd24e36e
8 changed files with 798 additions and 68 deletions

16
db/schema.rb generated
View File

@@ -10,7 +10,7 @@
#
# It's strongly recommended that you check this file into your version control system.
ActiveRecord::Schema[8.0].define(version: 2025_08_23_171354) do
ActiveRecord::Schema[8.0].define(version: 2025_08_25_012827) do
create_table "parties", force: :cascade do |t|
t.string "name", null: false
t.text "description", null: false
@@ -22,9 +22,10 @@ ActiveRecord::Schema[8.0].define(version: 2025_08_23_171354) do
t.decimal "latitude", precision: 10, scale: 6, null: false
t.decimal "longitude", precision: 10, scale: 6, null: false
t.boolean "featured", default: false, null: false
t.integer "user_id", null: false
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
t.bigint "user_id", null: false
t.string "image"
t.index ["featured"], name: "index_parties_on_featured"
t.index ["latitude", "longitude"], name: "index_parties_on_latitude_and_longitude"
t.index ["state"], name: "index_parties_on_state"
@@ -32,6 +33,7 @@ ActiveRecord::Schema[8.0].define(version: 2025_08_23_171354) do
end
create_table "ticket_types", force: :cascade do |t|
t.bigint "party_id", null: false
t.string "name"
t.text "description"
t.integer "price_cents"
@@ -40,7 +42,6 @@ ActiveRecord::Schema[8.0].define(version: 2025_08_23_171354) do
t.datetime "sale_end_at"
t.boolean "requires_id"
t.integer "minimum_age"
t.integer "party_id", null: false
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
t.index ["party_id"], name: "index_ticket_types_on_party_id"
@@ -52,8 +53,8 @@ ActiveRecord::Schema[8.0].define(version: 2025_08_23_171354) do
t.string "qr_code"
t.integer "price_cents"
t.string "status", default: "active"
t.integer "user_id", null: false
t.integer "ticket_type_id", null: false
t.bigint "user_id", null: false
t.bigint "ticket_type_id", null: false
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
t.index ["qr_code"], name: "index_tickets_on_qr_code", unique: true
@@ -72,4 +73,9 @@ ActiveRecord::Schema[8.0].define(version: 2025_08_23_171354) do
t.index ["email"], name: "index_users_on_email", unique: true
t.index ["reset_password_token"], name: "index_users_on_reset_password_token", unique: true
end
add_foreign_key "parties", "users"
add_foreign_key "ticket_types", "parties"
add_foreign_key "tickets", "ticket_types"
add_foreign_key "tickets", "users"
end