From 2980bbd1dc45c33119d17228b0ad35f4cf60ccd3 Mon Sep 17 00:00:00 2001 From: Cyrille Giquello Date: Fri, 15 May 2015 02:11:37 +0200 Subject: [PATCH] add some fields in rents & rentprices #8 --- app/Models/Rent.php | 13 +- app/Models/RentPrice.php | 17 +- .../2015_05_01_145614_create_rents_table.php | 4 +- ...5_05_01_145615_create_rentprices_table.php | 2 +- .../2015_05_14_215734_add_more_rent_data.php | 40 +++ ...5_05_14_220531_add_more_rentprice_data.php | 40 +++ resources/views/rentEdit.blade.php | 235 +++++++++++++----- resources/views/rentShow.blade.php | 42 ++-- 8 files changed, 308 insertions(+), 85 deletions(-) create mode 100644 database/migrations/2015_05_14_215734_add_more_rent_data.php create mode 100644 database/migrations/2015_05_14_220531_add_more_rentprice_data.php diff --git a/app/Models/Rent.php b/app/Models/Rent.php index 834185d..37e1da6 100644 --- a/app/Models/Rent.php +++ b/app/Models/Rent.php @@ -22,6 +22,7 @@ class Rent extends Model 'id', // FIXME : should not be there 'buildingIndividual', 'buildingStage', + 'buildingHLM', 'buildingName', 'street', 'zipcode', @@ -29,19 +30,21 @@ class Rent extends Model 'country', 'addrlat', 'addrlng', - 'geolocManual' // automatic or manual address geolocalization + 'geolocManual', // automatic or manual address geolocalization + 'roomsCount', + 'kitchenRoom', + 'surfaceM2' ]; public static $rules = [ 'buildingIndividual'=>'required|boolean', - 'buildingStage'=>'', - 'buildingName'=>'', + 'buildingHLM'=>'required|boolean', 'street'=>'required', 'zipcode'=>'required', 'city'=>'required', 'country'=>'required', - 'addrlat'=>'required', - 'addrlng'=>'required' + 'addrlat'=>'required|numeric', + 'addrlng'=>'required|numeric' ]; /** diff --git a/app/Models/RentPrice.php b/app/Models/RentPrice.php index 60049a7..36690dd 100644 --- a/app/Models/RentPrice.php +++ b/app/Models/RentPrice.php @@ -13,11 +13,22 @@ class RentPrice extends Model // http://laravel.com/docs/5.0/eloquent#soft-deleting use SoftDeletes; - protected $fillable = ['year', 'price']; + protected $fillable = [ + 'year', + 'month', + 'price', + 'loads', + 'loadsOther', + 'loadsOtherText', + ]; public static $rules = [ - 'year'=>'required|numeric', - 'price'=>'required|numeric' + 'year'=>'required|integer', + 'month'=>'required|integer', + 'price'=>'required|numeric', + 'loads'=>'required|numeric', + 'loadsOther'=>'numeric', + 'loadsOtherText'=>'numeric', ]; /** diff --git a/database/migrations/2015_05_01_145614_create_rents_table.php b/database/migrations/2015_05_01_145614_create_rents_table.php index da13f32..83be15c 100644 --- a/database/migrations/2015_05_01_145614_create_rents_table.php +++ b/database/migrations/2015_05_01_145614_create_rents_table.php @@ -15,13 +15,13 @@ public function up() Schema::create('rents', function(Blueprint $table) { $table->increments('id'); - $table->boolean('buildingIndividual'); + $table->boolean('buildingIndividual')->nullable(); $table->integer('buildingStage'); $table->string('buildingName'); $table->string('street'); $table->string('zipcode'); $table->string('city'); - $table->timestamps(); + $table->timestamps(); // Adds created_at and updated_at columns }); } diff --git a/database/migrations/2015_05_01_145615_create_rentprices_table.php b/database/migrations/2015_05_01_145615_create_rentprices_table.php index d3a98bd..717df64 100644 --- a/database/migrations/2015_05_01_145615_create_rentprices_table.php +++ b/database/migrations/2015_05_01_145615_create_rentprices_table.php @@ -21,7 +21,7 @@ public function up() $table->foreign('rent_id') ->references('id')->on('rents') ->onDelete('cascade'); - $table->timestamps(); + $table->timestamps(); // Adds created_at and updated_at columns }); } diff --git a/database/migrations/2015_05_14_215734_add_more_rent_data.php b/database/migrations/2015_05_14_215734_add_more_rent_data.php new file mode 100644 index 0000000..2552e44 --- /dev/null +++ b/database/migrations/2015_05_14_215734_add_more_rent_data.php @@ -0,0 +1,40 @@ +boolean('buildingHLM')->nullable()->after('buildingIndividual'); + $table->double('surfaceM2')->default(0.0)->after('buildingHLM'); + $table->integer('roomsCount')->default(0)->after('surfaceM2'); + $table->boolean('kitchenRoom')->nullable()->after('roomsCount'); + }); + } + + /** + * Reverse the migrations. + * + * @return void + */ + public function down() + { + Schema::table('rents', function(Blueprint $table) + { + $table->removeColumn('buildingHLM'); + $table->removeColumn('roomsCount'); + $table->removeColumn('surfaceM2'); + $table->removeColumn('kitchenRoom'); + }); + } + +} diff --git a/database/migrations/2015_05_14_220531_add_more_rentprice_data.php b/database/migrations/2015_05_14_220531_add_more_rentprice_data.php new file mode 100644 index 0000000..55cc0fa --- /dev/null +++ b/database/migrations/2015_05_14_220531_add_more_rentprice_data.php @@ -0,0 +1,40 @@ +integer('month')->after('year')->default(0); + $table->double('loads')->after('price')->default(0.0); + $table->double('loadsOther')->default(0.0)->after('loads'); + $table->string('loadsOtherText')->nullable()->after('loadsOther'); + }); + } + + /** + * Reverse the migrations. + * + * @return void + */ + public function down() + { + Schema::table('rent_prices', function(Blueprint $table) + { + $table->removeColumn('month'); + $table->removeColumn('loads'); + $table->removeColumn('loadsOther'); + $table->removeColumn('loadsOtherText'); + }); + } + +} diff --git a/resources/views/rentEdit.blade.php b/resources/views/rentEdit.blade.php index c860ef0..bdc7a84 100644 --- a/resources/views/rentEdit.blade.php +++ b/resources/views/rentEdit.blade.php @@ -25,63 +25,130 @@

Adresse

-
+ +
-

La bâtiment héberge-t-il un (individuel) ou plusieurs logements (collectif).

- @if ($errors->first('buildingIndividual')) + La bâtiment héberge-t-il un (individuel) ou plusieurs logements (collectif). +
+ @if ($errors->first('buildingIndividual'))

error {{$errors->first('buildingIndividual')}}

- @endif + @endif +
+ +
+ +
+ + + Est-ce un logement à loyer modéré ?
+ @if ($errors->first('buildingHLM')) +

error {{$errors->first('buildingHLM')}}

+ @endif
-
-
-
- - - @if ($errors->first('buildingStage')) -

error {{$errors->first('buildingStage')}}

- @endif + +
+ +
+
+ @if ($errors->first('surfaceM2')) +

error {{$errors->first('surfaceM2')}}

+ @endif +
+ +
+ +
+ +
+ @if ($errors->first('roomsCount')) +

error {{$errors->first('roomsCount')}}

+ @endif +
+ +
+ +
+ + + La cuisine est-elle une pièce dédiée ?
+ @if ($errors->first('kitchenRoom')) +

error {{$errors->first('kitchenRoom')}}

+ @endif
+ +
+ +
+ +
+ @if ($errors->first('buildingStage')) +

error {{$errors->first('buildingStage')}}

+ @endif +
+
- - + +
+ +
@if ($errors->first('buildingName')) -

error {{$errors->first('buildingName')}}

+

error {{$errors->first('buildingName')}}

@endif
+
- - + +
+ +
@if ($errors->first('street')) -

error {{$errors->first('street')}}

+

error {{$errors->first('street')}}

@endif
+
- - + +
+ +
@if ($errors->first('zipcode')) -

error {{$errors->first('zipcode')}}

+

error {{$errors->first('zipcode')}}

@endif
+
- - + +
+ +
@if ($errors->first('city')) -

error {{$errors->first('city')}}

+

error {{$errors->first('city')}}

@endif
+
- - + +
+ +
@if ($errors->first('country')) -

error {{$errors->first('country')}}

+

error {{$errors->first('country')}}

@endif
@@ -91,64 +158,112 @@ @include('rentEdit-map') -
-
- - + +
+ +
+ +
@if ($errors->first('addrlat'))

error {{$errors->first('addrlat')}}

@endif
-
- - +
+ +
+ +
@if ($errors->first('addrlng'))

error {{$errors->first('addrlng')}}

@endif
-

Loyers

-

Indiquez les loyers par année.

+

Saisie des loyers.

@foreach($rent->prices as $price) -
- -
- -
- - - @if( $errors->first('year'.$rowsCount) ) -

error {{$errors->first('year'.$rowsCount)}}

- @endif -
+
+ +
+
+
+ +
+ + + @if( $errors->first('year'.$rowsCount) ) +

error {{$errors->first('year'.$rowsCount)}}

+ @endif +
+ +
+ + + @if( $errors->first('month'.$rowsCount) ) +

error {{$errors->first('month'.$rowsCount)}}

+ @endif +
+ +
+ + + @if( $errors->first('price'.$rowsCount) ) +

error {{$errors->first('price'.$rowsCount)}}

+ @endif +
+ +
+ +
-
- - - @if( $errors->first('price'.$rowsCount) ) -

error {{$errors->first('price'.$rowsCount)}}

- @endif
-
- + +
+ +
+ + + @if( $errors->first('loads'.$rowsCount) ) +

error {{$errors->first('loads'.$rowsCount)}}

+ @endif +
+
+ + + @if( $errors->first('loadsOther'.$rowsCount) ) +

error {{$errors->first('loadsOther'.$rowsCount)}}

+ @endif +
+
+ + + @if( $errors->first('loadsOtherText'.$rowsCount) ) +

error {{$errors->first('loadsOtherText'.$rowsCount)}}

+ @endif +
+
+
+
@endforeach + Ajouter un loyer

diff --git a/resources/views/rentShow.blade.php b/resources/views/rentShow.blade.php index 0480e1a..02fe4ed 100644 --- a/resources/views/rentShow.blade.php +++ b/resources/views/rentShow.blade.php @@ -23,17 +23,24 @@
- - - - - - - - - - - + + + + + + + + + + + + + + + + + +
Logement@if($rent->buildingIndividual==1) collectif @else individuel @endif
Étage{{$rent->buildingStage}}
Nom{{$rent->buildingName}}
Rue{{$rent->street}}
Code postal{{$rent->zipcode}}
Ville{{$rent->city}}
Pays{{$rent->country}}
Latitude{{$rent->addrlat}}
Longitude{{$rent->addrlng}}
Créé le{{$rent->created_at}}
Mise à jour le{{$rent->updated_at}}
Logement @if($rent->buildingIndividual==1) collectif @else individuel @endif
HLM @if($rent->buildingHLM==1) oui @else non @endif
Surface {{ $rent->surfaceM2 }}
Nbr pièces {{ $rent->roomsCount }}
Cuisine séparée {{ $rent->kitchenRoom }}
Étage{{$rent->buildingStage}}
Nom{{$rent->buildingName}}
Rue{{$rent->street}}
Code postal{{$rent->zipcode}}
Ville{{$rent->city}}
Pays{{$rent->country}}
Latitude{{$rent->addrlat}}
Longitude{{$rent->addrlng}}
Créé le{{$rent->created_at}}
Mise à jour le{{$rent->updated_at}}
@@ -44,10 +51,17 @@

Loyers

-@foreach($rent->prices as $rentPrice) - -@endforeach + @foreach($rent->prices as $rentPrice) + + + + + + + + @endforeach
{{$rentPrice->year}}{{$rentPrice->price}}
{{$rentPrice->year}} {{$rentPrice->price}} {{$rentPrice->loads}} {{$rentPrice->loadsOther}} {{$rentPrice->loadsOtherText}}
+ @stop