I have a many-to-many pivot relation between two models of a Property, and a date that a user can see if the room is available for reserve or not. Everything is working fine until I want to search for the available date. My user submits two dates, and I want to sort all dates related to that room and show the days between those two user inputs. I know and tried dateBetween, but because I'm using a pivot table, i must somehow do this on sort and search collection instance. This is my collection, and I want to see if it's possible to sort and do an operation on it.
Collection {#1606 ▼
#items: array:1 [▼
0 => Property {#1441 ▼
#connection: "mysql"
#table: "properties"
#primaryKey: "id"
#keyType: "int"
+incrementing: true
#with: []
#withCount: []
#perPage: 15
+exists: true
+wasRecentlyCreated: false
#attributes: array:14 [▶]
#original: array:14 [▶]
#changes: []
#casts: []
#dates: []
#dateFormat: null
#appends: []
#dispatchesEvents: []
#observables: []
#relations: array:1 [▼
"dates" => Collection {#1605 ▼
#items: array:5 [▼
0 => Date {#1586 ▼
#connection: "mysql"
#table: "dates"
#primaryKey: "id"
#keyType: "int"
+incrementing: true
#with: []
#withCount: []
#perPage: 15
+exists: true
+wasRecentlyCreated: false
#attributes: array:5 [▼
"id" => 1
"date" => "2019-03-31 00:00:00"
"price" => 21000.0
"created_at" => "2019-03-31 00:00:00"
"updated_at" => null
]
#original: array:7 [▶]
#changes: []
#casts: []
#dates: []
#dateFormat: null
#appends: []
#dispatchesEvents: []
#observables: []
#relations: array:1 [▶]
#touches: []
+timestamps: true
#hidden: []
#visible: []
#fillable: []
#guarded: array:1 [▶]
}
1 => Date {#1587 ▶}
2 => Date {#1588 ▶}
3 => Date {#1589 ▶}
4 => Date {#1590 ▶}
]
}
]
#touches: []
+timestamps: true
#hidden: []
#visible: []
#fillable: []
#guarded: array:1 [▶]
}
]
Controller
if (!empty($request->start_date))
{
$pdate = Property::with('dates')->get();
// Here on pdate i wana do some sorting and searching base on user send start and end date
dd($pdate);
}
Date table
Schema::create('dates', function (Blueprint $table) {
$table->bigIncrements('id');
$table->dateTime('date');
$table->float('price');
$table->timestamps();
});
Property table
public function up()
{
Schema::create('properties', function (Blueprint $table) {
$table->bigIncrements('id');
$table->integer('type');
$table->text('title');
$table->longText('description');
$table->longText('image');
$table->float('base_price');
$table->dateTime('available_start');
$table->dateTime('available_end');
$table->integer('base_availability');
$table->integer('base_capacity');
$table->integer('max_occupancy');
$table->float('extra_price');
$table->timestamps();
});
}
Pivot table
Schema::create('date_property', function (Blueprint $table) {
$table->bigIncrements('id');
$table->integer('property_id');
$table->foreign('property_id')->references('id')->on('property');
$table->integer('date_id');
$table->foreign('date_id')->references('id')->on('date');
$table->integer('reserved');
$table->timestamps();
});
via Chebli Mohamed
Aucun commentaire:
Enregistrer un commentaire