demarches-normaliennes/app/controllers/carte_controller.rb
Xavier J cfee2a6ddf Revu de code de la partie "/dossiers/dossier_id:/carte" :
/app/controllers/carte_controller.rb
- l10/11 @dossier.update_attributes()
- l27 : le @dossier ne semble pas necessaire
- l32 : update attributes Ajouter :
	def dossier_id params[:dossier_id] end

/spec/controllers/carte_controller_spec.rb
- l 11/16 : utiliser nouvelle syntaxe pour les hashs : get :show, dossier_id: dossier_id
- l32 bancal : Commentaire.last.id, en theorie tu n'as jamais besoin d'écrire de requête sql dans tes tests l36 subject { Commentaire.last }
- l64, le cas ou c'est en erreur n'est pas testé (le géocodeur renvoie nil)
2015-08-12 14:02:40 +02:00

43 lines
No EOL
1.4 KiB
Ruby

class CarteController < ApplicationController
include DossierConcern
centre_de_la_France = 'Vesdun'
def show
@dossier = current_dossier
rescue
redirect_to url_for({controller: :start, action: :error_dossier})
end
def save_ref_api_carto
dossier = current_dossier
dossier.update_attributes(ref_dossier: params[:ref_dossier])
if params[:back_url] == 'recapitulatif'
commentaire = Commentaire.new
commentaire.email = 'Modification localisation'
commentaire.body = 'La localisation de la demande a été modifiée. Merci de le prendre en compte.'
commentaire.dossier = dossier
commentaire.save
redirect_to url_for({controller: :recapitulatif, action: :show, :dossier_id => params[:dossier_id]})
else
redirect_to url_for({controller: :description, action: :show, :dossier_id => params[:dossier_id]})
end
end
def get_position
dossier = current_dossier
if dossier.position_lat == nil
tmp_position = Carto::Geocodeur.convert_adresse_to_point(dossier.etablissement.adresse.gsub("\r\n", ' '))
if tmp_position.point == nil
dossier.update_attributes(position_lat: '0', position_lon: '0')
else
dossier.update_attributes(position_lat: tmp_position.point.y, position_lon: tmp_position.point.x)
end
end
render json: { lon: dossier.position_lon, lat: dossier.position_lat, dossier_id: params[:dossier_id] }
end
end