- Save QP on database
- Display on all Map (User and Gestionnaire)
This commit is contained in:
parent
f4e63d40b0
commit
eb5985efc4
9 changed files with 108 additions and 22 deletions
|
@ -17,8 +17,6 @@ function initCarto() {
|
|||
layers: [OSM]
|
||||
});
|
||||
|
||||
display_qp([]);
|
||||
|
||||
freeDraw = new L.FreeDraw({
|
||||
//mode: L.FreeDraw.MODES.CREATE
|
||||
});
|
||||
|
@ -36,6 +34,8 @@ function initCarto() {
|
|||
map.setView(new L.LatLng(position.lat, position.lon), 5);
|
||||
|
||||
add_event_freeDraw();
|
||||
|
||||
display_qp(JSON.parse($("#quartier_prioritaires").val()));
|
||||
}
|
||||
|
||||
function add_event_freeDraw() {
|
||||
|
@ -94,10 +94,13 @@ function display_qp(qp_list) {
|
|||
|
||||
new_qpLayer();
|
||||
|
||||
console.log(qp_list);
|
||||
|
||||
if (qp_array.length > 0) {
|
||||
qp_array.forEach(function (qp) {
|
||||
$("#qp_list ul").append('<li>' + qp.commune + ' : ' + qp.nom + '</li>');
|
||||
qpItems.addData(qp.geometry)
|
||||
|
||||
qpItems.addData(qp.geometry);
|
||||
});
|
||||
}
|
||||
else
|
||||
|
|
|
@ -8,9 +8,21 @@ class Users::CarteController < UsersController
|
|||
redirect_to url_for(root_path)
|
||||
end
|
||||
|
||||
#TODO change name funtion
|
||||
def save_ref_api_carto
|
||||
def save
|
||||
dossier = current_user_dossier
|
||||
|
||||
dossier.quartier_prioritaires.all.map(&:destroy)
|
||||
|
||||
unless params[:json_latlngs] == '' || params[:json_latlngs] == '[]'
|
||||
qp_list = generate_qp JSON.parse(params[:json_latlngs]);
|
||||
|
||||
qp_list.each do |key, qp|
|
||||
qp.merge!({dossier_id: dossier.id})
|
||||
qp[:geometry] = qp[:geometry].to_json
|
||||
QuartierPrioritaire.new(qp).save
|
||||
end
|
||||
end
|
||||
|
||||
dossier.update_attributes(json_latlngs: params[:json_latlngs])
|
||||
|
||||
if dossier.draft?
|
||||
|
@ -38,9 +50,7 @@ class Users::CarteController < UsersController
|
|||
end
|
||||
|
||||
def get_qp
|
||||
coordinates = JSON.parse(params[:coordinates])
|
||||
|
||||
qp = generate_qp coordinates
|
||||
qp = generate_qp JSON.parse(params[:coordinates])
|
||||
|
||||
render json: {quartier_prioritaires: qp}
|
||||
end
|
||||
|
|
|
@ -1,3 +1,7 @@
|
|||
class QuartierPrioritaire < ActiveRecord::Base
|
||||
belongs_to :dossier
|
||||
|
||||
def geometry
|
||||
JSON.parse(read_attribute(:geometry))
|
||||
end
|
||||
end
|
||||
|
|
|
@ -17,6 +17,7 @@
|
|||
.col-lg-6.col-md-6
|
||||
#map.mini
|
||||
%input{id: 'json_latlngs', type:'hidden', value: "#{@dossier.json_latlngs}"}
|
||||
%input{id: 'quartier_prioritaires', type:'hidden', value: "#{@dossier.quartier_prioritaires.to_json}"}
|
||||
%script{type: 'text/javascript'}
|
||||
= "var dossier_id =#{@dossier.id}"
|
||||
initCarto();
|
||||
|
|
|
@ -17,9 +17,10 @@
|
|||
%h3 Quartiers prioritaites
|
||||
%ul
|
||||
|
||||
= form_tag(url_for({controller: :carte, action: :save_ref_api_carto, dossier_id: @dossier.id}), class: 'form-inline', method: 'POST') do
|
||||
= form_tag(url_for({controller: :carte, action: :save, dossier_id: @dossier.id}), class: 'form-inline', method: 'POST') do
|
||||
%br
|
||||
%input{type: 'hidden', value: "#{@dossier.json_latlngs}", name: 'json_latlngs', id: 'json_latlngs'}
|
||||
%input{id: 'quartier_prioritaires', type:'hidden', value: "#{@dossier.quartier_prioritaires.to_json}"}
|
||||
|
||||
-if @dossier.draft?
|
||||
=render partial: '/layouts/etape_suivante'
|
||||
|
|
|
@ -35,7 +35,7 @@ Rails.application.routes.draw do
|
|||
get '/carte/position' => 'carte#get_position'
|
||||
post '/carte/qp' => 'carte#get_qp'
|
||||
get '/carte' => 'carte#show'
|
||||
post '/carte' => 'carte#save_ref_api_carto'
|
||||
post '/carte' => 'carte#save'
|
||||
|
||||
end
|
||||
resource :dossiers
|
||||
|
@ -70,6 +70,7 @@ Rails.application.routes.draw do
|
|||
post 'valid' => 'dossiers#valid'
|
||||
post 'close' => 'dossiers#close'
|
||||
end
|
||||
|
||||
resources :commentaires, only: [:create]
|
||||
end
|
||||
|
||||
|
|
|
@ -6,7 +6,6 @@ RSpec.describe Users::CarteController, type: :controller do
|
|||
let(:dossier) { create(:dossier, :with_user, :with_procedure) }
|
||||
let!(:entreprise) { create(:entreprise, dossier: dossier) }
|
||||
let!(:etablissement) { create(:etablissement, dossier: dossier) }
|
||||
let(:dossier_id) { dossier.id }
|
||||
let(:bad_dossier_id) { Dossier.count + 1000 }
|
||||
let(:adresse) { etablissement.adresse }
|
||||
|
||||
|
@ -21,13 +20,13 @@ RSpec.describe Users::CarteController, type: :controller do
|
|||
end
|
||||
|
||||
it 'redirects to users/sign_in' do
|
||||
get :show, dossier_id: dossier_id
|
||||
get :show, dossier_id: dossier.id
|
||||
expect(response).to redirect_to('/users/sign_in')
|
||||
end
|
||||
end
|
||||
|
||||
it 'returns http success' do
|
||||
get :show, dossier_id: dossier_id
|
||||
get :show, dossier_id: dossier.id
|
||||
expect(response).to have_http_status(:success)
|
||||
end
|
||||
|
||||
|
@ -39,18 +38,18 @@ RSpec.describe Users::CarteController, type: :controller do
|
|||
it_behaves_like "not owner of dossier", :show
|
||||
end
|
||||
|
||||
describe 'POST #save_ref_api_carto' do
|
||||
describe 'POST #save' do
|
||||
context 'Aucune localisation n\'a jamais été enregistrée' do
|
||||
it do
|
||||
post :save_ref_api_carto, dossier_id: dossier_id
|
||||
expect(response).to redirect_to("/users/dossiers/#{dossier_id}/description")
|
||||
post :save, dossier_id: dossier.id, json_latlngs: ''
|
||||
expect(response).to redirect_to("/users/dossiers/#{dossier.id}/description")
|
||||
end
|
||||
end
|
||||
|
||||
context 'En train de modifier la localisation' do
|
||||
let(:dossier) { create(:dossier, :with_procedure, :with_user, state: 'initiated') }
|
||||
before do
|
||||
post :save_ref_api_carto, dossier_id: dossier_id
|
||||
post :save, dossier_id: dossier.id, json_latlngs: ''
|
||||
end
|
||||
|
||||
context 'Enregistrement d\'un commentaire informant la modification' do
|
||||
|
@ -65,12 +64,61 @@ RSpec.describe Users::CarteController, type: :controller do
|
|||
end
|
||||
|
||||
it 'champs dossier' do
|
||||
expect(subject.dossier.id).to eq(dossier_id)
|
||||
expect(subject.dossier.id).to eq(dossier.id)
|
||||
end
|
||||
end
|
||||
|
||||
it 'Redirection vers la page récapitulatif' do
|
||||
expect(response).to redirect_to("/users/dossiers/#{dossier_id}/recapitulatif")
|
||||
expect(response).to redirect_to("/users/dossiers/#{dossier.id}/recapitulatif")
|
||||
end
|
||||
end
|
||||
|
||||
describe 'Save quartier prioritaire' do
|
||||
before do
|
||||
allow_any_instance_of(CARTO::SGMAP::QuartierPrioritaireAdapter).
|
||||
to receive(:to_params).
|
||||
and_return({"QPCODE1234" => {:code => "QPCODE1234", :nom => "QP de test", :commune => "Paris", :geometry => {:type => "MultiPolygon", :coordinates => [[[[2.38715792094576, 48.8723062632126], [2.38724851642619, 48.8721392348061]]]]}}})
|
||||
|
||||
post :save, dossier_id: dossier.id, json_latlngs: json_latlngs
|
||||
end
|
||||
|
||||
context 'when json_latlngs params is empty' do
|
||||
context 'when dossier have quartier prioritaire in database' do
|
||||
let!(:dossier) { create(:dossier, :with_user, :with_procedure, :with_two_quartier_prioritaires) }
|
||||
|
||||
before do
|
||||
dossier.reload
|
||||
end
|
||||
|
||||
context 'when value is empty' do
|
||||
let(:json_latlngs) { '' }
|
||||
it { expect(dossier.quartier_prioritaires.size).to eq(0) }
|
||||
end
|
||||
|
||||
context 'when value is empty array' do
|
||||
let(:json_latlngs) { '[]' }
|
||||
it { expect(dossier.quartier_prioritaires.size).to eq(0) }
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
context 'when json_latlngs params is informed' do
|
||||
let(:json_latlngs) { '[[{"lat":48.87442541960633,"lng":2.3859214782714844},{"lat":48.87273183590832,"lng":2.3850631713867183},{"lat":48.87081237174292,"lng":2.3809432983398438},{"lat":48.8712640169951,"lng":2.377510070800781},{"lat":48.87510283703279,"lng":2.3778533935546875},{"lat":48.87544154230615,"lng":2.382831573486328},{"lat":48.87442541960633,"lng":2.3859214782714844}]]' }
|
||||
|
||||
before do
|
||||
dossier.reload
|
||||
end
|
||||
|
||||
it { expect(dossier.quartier_prioritaires.size).to eq(1) }
|
||||
|
||||
describe 'Quartier Prioritaire' do
|
||||
subject { QuartierPrioritaire.last }
|
||||
|
||||
it { expect(subject.code).to eq('QPCODE1234') }
|
||||
it { expect(subject.commune).to eq('Paris') }
|
||||
it { expect(subject.nom).to eq('QP de test') }
|
||||
it { expect(subject.dossier_id).to eq(dossier.id) }
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
@ -98,7 +146,7 @@ RSpec.describe Users::CarteController, type: :controller do
|
|||
stub_request(:get, "http://api-adresse.data.gouv.fr/search?limit=1&q=#{adresse}")
|
||||
.to_return(status: 200, body: '{"query": "50 avenue des champs u00e9lysu00e9es Paris 75008", "version": "draft", "licence": "ODbL 1.0", "features": [{"geometry": {"coordinates": [2.306888, 48.870374], "type": "Point"}, "type": "Feature", "properties": {"city": "Paris", "label": "50 Avenue des Champs u00c9lysu00e9es 75008 Paris", "housenumber": "50", "id": "ADRNIVX_0000000270748251", "postcode": "75008", "name": "50 Avenue des Champs u00c9lysu00e9es", "citycode": "75108", "context": "75, u00cele-de-France", "score": 0.9054545454545454, "type": "housenumber"}}], "type": "FeatureCollection", "attribution": "BAN"}', headers: {})
|
||||
|
||||
get :get_position, dossier_id: dossier_id
|
||||
get :get_position, dossier_id: dossier.id
|
||||
end
|
||||
subject { JSON.parse(response.body) }
|
||||
|
||||
|
@ -126,7 +174,7 @@ RSpec.describe Users::CarteController, type: :controller do
|
|||
to receive(:to_params).
|
||||
and_return({"QPCODE1234" => {:code => "QPCODE1234", :geometry => {:type => "MultiPolygon", :coordinates => [[[[2.38715792094576, 48.8723062632126], [2.38724851642619, 48.8721392348061]]]]}}})
|
||||
|
||||
post :get_qp, dossier_id: dossier_id, coordinates: coordinates
|
||||
post :get_qp, dossier_id: dossier.id, coordinates: coordinates
|
||||
end
|
||||
|
||||
context 'when coordinates are empty' do
|
||||
|
|
|
@ -24,5 +24,16 @@ FactoryGirl.define do
|
|||
dossier.user = create(:user)
|
||||
end
|
||||
end
|
||||
|
||||
trait :with_two_quartier_prioritaires do
|
||||
after(:build) do |dossier, _evaluator|
|
||||
|
||||
qp1 = create(:quartier_prioritaire)
|
||||
qp2 = create(:quartier_prioritaire)
|
||||
|
||||
dossier.quartier_prioritaires << qp1
|
||||
dossier.quartier_prioritaires << qp2
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
7
spec/factories/quartier_prioritaire.rb
Normal file
7
spec/factories/quartier_prioritaire.rb
Normal file
|
@ -0,0 +1,7 @@
|
|||
FactoryGirl.define do
|
||||
factory :quartier_prioritaire do
|
||||
code 'QPcode'
|
||||
commune 'Paris'
|
||||
nom 'Test des QP'
|
||||
end
|
||||
end
|
Loading…
Reference in a new issue