commit
dcfb33c6a1
57 changed files with 667 additions and 874 deletions
2
Gemfile
2
Gemfile
|
@ -60,7 +60,7 @@ gem 'puma' # Use Puma as the app server
|
||||||
gem 'pundit'
|
gem 'pundit'
|
||||||
gem 'rack-attack'
|
gem 'rack-attack'
|
||||||
gem 'rack-mini-profiler'
|
gem 'rack-mini-profiler'
|
||||||
gem 'rails', '6.0.3.2'
|
gem 'rails'
|
||||||
gem 'rails-i18n' # Locales par défaut
|
gem 'rails-i18n' # Locales par défaut
|
||||||
gem 'rake-progressbar', require: false
|
gem 'rake-progressbar', require: false
|
||||||
gem 'react-rails'
|
gem 'react-rails'
|
||||||
|
|
116
Gemfile.lock
116
Gemfile.lock
|
@ -11,38 +11,38 @@ GEM
|
||||||
specs:
|
specs:
|
||||||
aasm (5.0.8)
|
aasm (5.0.8)
|
||||||
concurrent-ruby (~> 1.0)
|
concurrent-ruby (~> 1.0)
|
||||||
actioncable (6.0.3.2)
|
actioncable (6.0.3.3)
|
||||||
actionpack (= 6.0.3.2)
|
actionpack (= 6.0.3.3)
|
||||||
nio4r (~> 2.0)
|
nio4r (~> 2.0)
|
||||||
websocket-driver (>= 0.6.1)
|
websocket-driver (>= 0.6.1)
|
||||||
actionmailbox (6.0.3.2)
|
actionmailbox (6.0.3.3)
|
||||||
actionpack (= 6.0.3.2)
|
actionpack (= 6.0.3.3)
|
||||||
activejob (= 6.0.3.2)
|
activejob (= 6.0.3.3)
|
||||||
activerecord (= 6.0.3.2)
|
activerecord (= 6.0.3.3)
|
||||||
activestorage (= 6.0.3.2)
|
activestorage (= 6.0.3.3)
|
||||||
activesupport (= 6.0.3.2)
|
activesupport (= 6.0.3.3)
|
||||||
mail (>= 2.7.1)
|
mail (>= 2.7.1)
|
||||||
actionmailer (6.0.3.2)
|
actionmailer (6.0.3.3)
|
||||||
actionpack (= 6.0.3.2)
|
actionpack (= 6.0.3.3)
|
||||||
actionview (= 6.0.3.2)
|
actionview (= 6.0.3.3)
|
||||||
activejob (= 6.0.3.2)
|
activejob (= 6.0.3.3)
|
||||||
mail (~> 2.5, >= 2.5.4)
|
mail (~> 2.5, >= 2.5.4)
|
||||||
rails-dom-testing (~> 2.0)
|
rails-dom-testing (~> 2.0)
|
||||||
actionpack (6.0.3.2)
|
actionpack (6.0.3.3)
|
||||||
actionview (= 6.0.3.2)
|
actionview (= 6.0.3.3)
|
||||||
activesupport (= 6.0.3.2)
|
activesupport (= 6.0.3.3)
|
||||||
rack (~> 2.0, >= 2.0.8)
|
rack (~> 2.0, >= 2.0.8)
|
||||||
rack-test (>= 0.6.3)
|
rack-test (>= 0.6.3)
|
||||||
rails-dom-testing (~> 2.0)
|
rails-dom-testing (~> 2.0)
|
||||||
rails-html-sanitizer (~> 1.0, >= 1.2.0)
|
rails-html-sanitizer (~> 1.0, >= 1.2.0)
|
||||||
actiontext (6.0.3.2)
|
actiontext (6.0.3.3)
|
||||||
actionpack (= 6.0.3.2)
|
actionpack (= 6.0.3.3)
|
||||||
activerecord (= 6.0.3.2)
|
activerecord (= 6.0.3.3)
|
||||||
activestorage (= 6.0.3.2)
|
activestorage (= 6.0.3.3)
|
||||||
activesupport (= 6.0.3.2)
|
activesupport (= 6.0.3.3)
|
||||||
nokogiri (>= 1.8.5)
|
nokogiri (>= 1.8.5)
|
||||||
actionview (6.0.3.2)
|
actionview (6.0.3.3)
|
||||||
activesupport (= 6.0.3.2)
|
activesupport (= 6.0.3.3)
|
||||||
builder (~> 3.1)
|
builder (~> 3.1)
|
||||||
erubi (~> 1.4)
|
erubi (~> 1.4)
|
||||||
rails-dom-testing (~> 2.0)
|
rails-dom-testing (~> 2.0)
|
||||||
|
@ -57,25 +57,25 @@ GEM
|
||||||
jsonapi-renderer (>= 0.1.1.beta1, < 0.3)
|
jsonapi-renderer (>= 0.1.1.beta1, < 0.3)
|
||||||
active_storage_validations (0.8.8)
|
active_storage_validations (0.8.8)
|
||||||
rails (>= 5.2.0)
|
rails (>= 5.2.0)
|
||||||
activejob (6.0.3.2)
|
activejob (6.0.3.3)
|
||||||
activesupport (= 6.0.3.2)
|
activesupport (= 6.0.3.3)
|
||||||
globalid (>= 0.3.6)
|
globalid (>= 0.3.6)
|
||||||
activemodel (6.0.3.2)
|
activemodel (6.0.3.3)
|
||||||
activesupport (= 6.0.3.2)
|
activesupport (= 6.0.3.3)
|
||||||
activerecord (6.0.3.2)
|
activerecord (6.0.3.3)
|
||||||
activemodel (= 6.0.3.2)
|
activemodel (= 6.0.3.3)
|
||||||
activesupport (= 6.0.3.2)
|
activesupport (= 6.0.3.3)
|
||||||
activestorage (6.0.3.2)
|
activestorage (6.0.3.3)
|
||||||
actionpack (= 6.0.3.2)
|
actionpack (= 6.0.3.3)
|
||||||
activejob (= 6.0.3.2)
|
activejob (= 6.0.3.3)
|
||||||
activerecord (= 6.0.3.2)
|
activerecord (= 6.0.3.3)
|
||||||
marcel (~> 0.3.1)
|
marcel (~> 0.3.1)
|
||||||
activestorage-openstack (1.4.1)
|
activestorage-openstack (1.4.1)
|
||||||
fog-openstack (~> 1.0)
|
fog-openstack (~> 1.0)
|
||||||
marcel
|
marcel
|
||||||
mime-types
|
mime-types
|
||||||
rails (>= 5.2.2)
|
rails (>= 5.2.2)
|
||||||
activesupport (6.0.3.2)
|
activesupport (6.0.3.3)
|
||||||
concurrent-ruby (~> 1.0, >= 1.0.2)
|
concurrent-ruby (~> 1.0, >= 1.0.2)
|
||||||
i18n (>= 0.7, < 2)
|
i18n (>= 0.7, < 2)
|
||||||
minitest (~> 5.1)
|
minitest (~> 5.1)
|
||||||
|
@ -169,7 +169,7 @@ GEM
|
||||||
coffee-script-source
|
coffee-script-source
|
||||||
execjs
|
execjs
|
||||||
coffee-script-source (1.12.2)
|
coffee-script-source (1.12.2)
|
||||||
concurrent-ruby (1.1.6)
|
concurrent-ruby (1.1.7)
|
||||||
connection_pool (2.2.2)
|
connection_pool (2.2.2)
|
||||||
crack (0.4.3)
|
crack (0.4.3)
|
||||||
safe_yaml (~> 1.0.0)
|
safe_yaml (~> 1.0.0)
|
||||||
|
@ -340,7 +340,7 @@ GEM
|
||||||
http_accept_language (2.1.1)
|
http_accept_language (2.1.1)
|
||||||
http_parser.rb (0.6.0)
|
http_parser.rb (0.6.0)
|
||||||
httpclient (2.8.3)
|
httpclient (2.8.3)
|
||||||
i18n (1.8.3)
|
i18n (1.8.5)
|
||||||
concurrent-ruby (~> 1.0)
|
concurrent-ruby (~> 1.0)
|
||||||
ice_nine (0.11.2)
|
ice_nine (0.11.2)
|
||||||
ipaddress (0.8.3)
|
ipaddress (0.8.3)
|
||||||
|
@ -384,7 +384,7 @@ GEM
|
||||||
railties (>= 4)
|
railties (>= 4)
|
||||||
request_store (~> 1.0)
|
request_store (~> 1.0)
|
||||||
logstash-event (1.2.02)
|
logstash-event (1.2.02)
|
||||||
loofah (2.6.0)
|
loofah (2.7.0)
|
||||||
crass (~> 1.0.2)
|
crass (~> 1.0.2)
|
||||||
nokogiri (>= 1.5.9)
|
nokogiri (>= 1.5.9)
|
||||||
lumberjack (1.2.4)
|
lumberjack (1.2.4)
|
||||||
|
@ -403,7 +403,7 @@ GEM
|
||||||
mimemagic (0.3.5)
|
mimemagic (0.3.5)
|
||||||
mini_mime (1.0.2)
|
mini_mime (1.0.2)
|
||||||
mini_portile2 (2.4.0)
|
mini_portile2 (2.4.0)
|
||||||
minitest (5.14.1)
|
minitest (5.14.2)
|
||||||
momentjs-rails (2.20.1)
|
momentjs-rails (2.20.1)
|
||||||
railties (>= 3.1)
|
railties (>= 3.1)
|
||||||
multi_json (1.15.0)
|
multi_json (1.15.0)
|
||||||
|
@ -413,7 +413,7 @@ GEM
|
||||||
ruby2_keywords (~> 0.0.1)
|
ruby2_keywords (~> 0.0.1)
|
||||||
nenv (0.3.0)
|
nenv (0.3.0)
|
||||||
netrc (0.11.0)
|
netrc (0.11.0)
|
||||||
nio4r (2.5.2)
|
nio4r (2.5.3)
|
||||||
nokogiri (1.10.10)
|
nokogiri (1.10.10)
|
||||||
mini_portile2 (~> 2.4.0)
|
mini_portile2 (~> 2.4.0)
|
||||||
notiffany (0.1.3)
|
notiffany (0.1.3)
|
||||||
|
@ -504,20 +504,20 @@ GEM
|
||||||
rack
|
rack
|
||||||
rack-test (1.1.0)
|
rack-test (1.1.0)
|
||||||
rack (>= 1.0, < 3)
|
rack (>= 1.0, < 3)
|
||||||
rails (6.0.3.2)
|
rails (6.0.3.3)
|
||||||
actioncable (= 6.0.3.2)
|
actioncable (= 6.0.3.3)
|
||||||
actionmailbox (= 6.0.3.2)
|
actionmailbox (= 6.0.3.3)
|
||||||
actionmailer (= 6.0.3.2)
|
actionmailer (= 6.0.3.3)
|
||||||
actionpack (= 6.0.3.2)
|
actionpack (= 6.0.3.3)
|
||||||
actiontext (= 6.0.3.2)
|
actiontext (= 6.0.3.3)
|
||||||
actionview (= 6.0.3.2)
|
actionview (= 6.0.3.3)
|
||||||
activejob (= 6.0.3.2)
|
activejob (= 6.0.3.3)
|
||||||
activemodel (= 6.0.3.2)
|
activemodel (= 6.0.3.3)
|
||||||
activerecord (= 6.0.3.2)
|
activerecord (= 6.0.3.3)
|
||||||
activestorage (= 6.0.3.2)
|
activestorage (= 6.0.3.3)
|
||||||
activesupport (= 6.0.3.2)
|
activesupport (= 6.0.3.3)
|
||||||
bundler (>= 1.3.0)
|
bundler (>= 1.3.0)
|
||||||
railties (= 6.0.3.2)
|
railties (= 6.0.3.3)
|
||||||
sprockets-rails (>= 2.0.0)
|
sprockets-rails (>= 2.0.0)
|
||||||
rails-controller-testing (1.0.4)
|
rails-controller-testing (1.0.4)
|
||||||
actionpack (>= 5.0.1.x)
|
actionpack (>= 5.0.1.x)
|
||||||
|
@ -536,9 +536,9 @@ GEM
|
||||||
rails-i18n (6.0.0)
|
rails-i18n (6.0.0)
|
||||||
i18n (>= 0.7, < 2)
|
i18n (>= 0.7, < 2)
|
||||||
railties (>= 6.0.0, < 7)
|
railties (>= 6.0.0, < 7)
|
||||||
railties (6.0.3.2)
|
railties (6.0.3.3)
|
||||||
actionpack (= 6.0.3.2)
|
actionpack (= 6.0.3.3)
|
||||||
activesupport (= 6.0.3.2)
|
activesupport (= 6.0.3.3)
|
||||||
method_source
|
method_source
|
||||||
rake (>= 0.8.7)
|
rake (>= 0.8.7)
|
||||||
thor (>= 0.20.3, < 2.0)
|
thor (>= 0.20.3, < 2.0)
|
||||||
|
@ -682,7 +682,7 @@ GEM
|
||||||
sprockets (3.7.2)
|
sprockets (3.7.2)
|
||||||
concurrent-ruby (~> 1.0)
|
concurrent-ruby (~> 1.0)
|
||||||
rack (> 1, < 3)
|
rack (> 1, < 3)
|
||||||
sprockets-rails (3.2.1)
|
sprockets-rails (3.2.2)
|
||||||
actionpack (>= 4.0)
|
actionpack (>= 4.0)
|
||||||
activesupport (>= 4.0)
|
activesupport (>= 4.0)
|
||||||
sprockets (>= 3.0.0)
|
sprockets (>= 3.0.0)
|
||||||
|
@ -740,7 +740,7 @@ GEM
|
||||||
rack-proxy (>= 0.6.1)
|
rack-proxy (>= 0.6.1)
|
||||||
railties (>= 5.2)
|
railties (>= 5.2)
|
||||||
semantic_range (>= 2.3.0)
|
semantic_range (>= 2.3.0)
|
||||||
websocket-driver (0.7.2)
|
websocket-driver (0.7.3)
|
||||||
websocket-extensions (>= 0.1.0)
|
websocket-extensions (>= 0.1.0)
|
||||||
websocket-extensions (0.1.5)
|
websocket-extensions (0.1.5)
|
||||||
xpath (3.2.0)
|
xpath (3.2.0)
|
||||||
|
@ -837,7 +837,7 @@ DEPENDENCIES
|
||||||
pundit
|
pundit
|
||||||
rack-attack
|
rack-attack
|
||||||
rack-mini-profiler
|
rack-mini-profiler
|
||||||
rails (= 6.0.3.2)
|
rails
|
||||||
rails-controller-testing
|
rails-controller-testing
|
||||||
rails-erd
|
rails-erd
|
||||||
rails-i18n
|
rails-i18n
|
||||||
|
|
|
@ -25,6 +25,10 @@
|
||||||
justify-content: flex-start;
|
justify-content: flex-start;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&.justify-end {
|
||||||
|
justify-content: flex-end;
|
||||||
|
}
|
||||||
|
|
||||||
&.wrap {
|
&.wrap {
|
||||||
flex-wrap: wrap;
|
flex-wrap: wrap;
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.mb-4 {
|
.mb-4 {
|
||||||
margin-bottom: 4 * $default-spacer;
|
margin-bottom: 4 * $default-spacer !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ml-1 {
|
.ml-1 {
|
||||||
|
@ -20,6 +20,10 @@
|
||||||
padding-left: 0px !important;
|
padding-left: 0px !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.bold {
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
.numbers-delimiter {
|
.numbers-delimiter {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
width: 5px;
|
width: 5px;
|
||||||
|
|
|
@ -192,9 +192,6 @@ $header-mobile-breakpoint: 550px;
|
||||||
background: none;
|
background: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
&::after {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.header-menu {
|
.header-menu {
|
||||||
|
|
|
@ -62,40 +62,6 @@ class Admin::ProceduresController < AdminController
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def publish_validate
|
|
||||||
@procedure.assign_attributes(publish_params)
|
|
||||||
end
|
|
||||||
|
|
||||||
def publish
|
|
||||||
@procedure.assign_attributes(publish_params)
|
|
||||||
|
|
||||||
@procedure.publish_or_reopen!(current_administrateur)
|
|
||||||
|
|
||||||
flash.notice = "Démarche publiée"
|
|
||||||
render js: "window.location='#{admin_procedures_path}'"
|
|
||||||
rescue ActiveRecord::RecordInvalid
|
|
||||||
respond_to do |format|
|
|
||||||
format.js { render :publish_validate }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def transfer
|
|
||||||
admin = Administrateur.by_email(params[:email_admin].downcase)
|
|
||||||
|
|
||||||
if admin.nil?
|
|
||||||
respond_to do |format|
|
|
||||||
format.js { render :transfer, status: :not_found }
|
|
||||||
end
|
|
||||||
else
|
|
||||||
procedure = current_administrateur.procedures.find(params[:procedure_id])
|
|
||||||
procedure.clone(admin, false)
|
|
||||||
|
|
||||||
flash.now.notice = "La démarche a correctement été clonée vers le nouvel administrateur."
|
|
||||||
|
|
||||||
respond_to(&:js)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def archive
|
def archive
|
||||||
procedure = current_administrateur.procedures.find(params[:procedure_id])
|
procedure = current_administrateur.procedures.find(params[:procedure_id])
|
||||||
procedure.close!
|
procedure.close!
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
module NewAdministrateur
|
module NewAdministrateur
|
||||||
class ProceduresController < AdministrateurController
|
class ProceduresController < AdministrateurController
|
||||||
before_action :retrieve_procedure, only: [:champs, :annotations, :edit, :monavis, :update_monavis, :jeton, :update_jeton]
|
before_action :retrieve_procedure, only: [:champs, :annotations, :edit, :monavis, :update_monavis, :jeton, :update_jeton, :publication, :publish]
|
||||||
before_action :procedure_locked?, only: [:champs, :annotations]
|
before_action :procedure_locked?, only: [:champs, :annotations]
|
||||||
|
|
||||||
ITEMS_PER_PAGE = 25
|
ITEMS_PER_PAGE = 25
|
||||||
|
@ -132,6 +132,41 @@ module NewAdministrateur
|
||||||
render 'jeton'
|
render 'jeton'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def publication
|
||||||
|
if @procedure.brouillon?
|
||||||
|
@procedure_lien = commencer_test_url(path: @procedure.path)
|
||||||
|
else
|
||||||
|
@procedure_lien = commencer_url(path: @procedure.path)
|
||||||
|
end
|
||||||
|
@procedure.path = @procedure.suggested_path(current_administrateur)
|
||||||
|
@current_administrateur = current_administrateur
|
||||||
|
end
|
||||||
|
|
||||||
|
def publish
|
||||||
|
@procedure.assign_attributes(publish_params)
|
||||||
|
|
||||||
|
if @procedure.publish_or_reopen!(current_administrateur)
|
||||||
|
redirect_to admin_procedure_path(@procedure)
|
||||||
|
flash.notice = "Démarche publiée"
|
||||||
|
else
|
||||||
|
redirect_to admin_procedure_path(@procedure)
|
||||||
|
flash.alert = @procedure.errors.full_messages
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def transfer
|
||||||
|
admin = Administrateur.by_email(params[:email_admin].downcase)
|
||||||
|
if admin.nil?
|
||||||
|
redirect_to admin_procedure_publication_path(params[:procedure_id])
|
||||||
|
flash.alert = "Envoi vers #{params[:email_admin]} impossible : cet administrateur n'existe pas"
|
||||||
|
else
|
||||||
|
procedure = current_administrateur.procedures.find(params[:procedure_id])
|
||||||
|
procedure.clone(admin, false)
|
||||||
|
redirect_to admin_procedure_path(params[:procedure_id])
|
||||||
|
flash.notice = "La démarche a correctement été clonée vers le nouvel administrateur."
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def apercu_tab
|
def apercu_tab
|
||||||
|
@ -154,5 +189,9 @@ module NewAdministrateur
|
||||||
end
|
end
|
||||||
permited_params
|
permited_params
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def publish_params
|
||||||
|
params.permit(:path, :lien_site_web)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -56,30 +56,27 @@ module NewAdministrateur
|
||||||
:updated_at
|
:updated_at
|
||||||
],
|
],
|
||||||
methods: [
|
methods: [
|
||||||
:cadastres,
|
|
||||||
:drop_down_list_value,
|
:drop_down_list_value,
|
||||||
:parcelles_agricoles,
|
|
||||||
:piece_justificative_template_filename,
|
:piece_justificative_template_filename,
|
||||||
:piece_justificative_template_url,
|
:piece_justificative_template_url,
|
||||||
:quartiers_prioritaires
|
:cadastres,
|
||||||
|
:mnhn
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
def type_de_champ_create_params
|
def type_de_champ_create_params
|
||||||
type_de_champ_params = params.required(:type_de_champ).permit(:cadastres,
|
type_de_champ_params = params.required(:type_de_champ).permit(:type_champ,
|
||||||
:description,
|
|
||||||
:drop_down_list_value,
|
|
||||||
:libelle,
|
:libelle,
|
||||||
|
:description,
|
||||||
:mandatory,
|
:mandatory,
|
||||||
:order_place,
|
|
||||||
:parcelles_agricoles,
|
|
||||||
:parent_id,
|
:parent_id,
|
||||||
:piece_justificative_template,
|
|
||||||
:private,
|
:private,
|
||||||
:quartiers_prioritaires,
|
:drop_down_list_value,
|
||||||
:type_champ)
|
:piece_justificative_template,
|
||||||
|
:cadastres,
|
||||||
|
:mnhn)
|
||||||
|
|
||||||
if type_de_champ_params[:parent_id].present?
|
if type_de_champ_params[:parent_id].present?
|
||||||
type_de_champ_params[:parent_id] = TypeDeChamp.to_stable_id(type_de_champ_params[:parent_id])
|
type_de_champ_params[:parent_id] = TypeDeChamp.to_stable_id(type_de_champ_params[:parent_id])
|
||||||
|
@ -89,15 +86,14 @@ module NewAdministrateur
|
||||||
end
|
end
|
||||||
|
|
||||||
def type_de_champ_update_params
|
def type_de_champ_update_params
|
||||||
params.required(:type_de_champ).permit(:cadastres,
|
params.required(:type_de_champ).permit(:type_champ,
|
||||||
:description,
|
|
||||||
:drop_down_list_value,
|
|
||||||
:libelle,
|
:libelle,
|
||||||
|
:description,
|
||||||
:mandatory,
|
:mandatory,
|
||||||
:parcelles_agricoles,
|
:drop_down_list_value,
|
||||||
:piece_justificative_template,
|
:piece_justificative_template,
|
||||||
:quartiers_prioritaires,
|
:cadastres,
|
||||||
:type_champ)
|
:mnhn)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -13,7 +13,7 @@ module ProcedureHelper
|
||||||
safe_join(parts, ' ')
|
safe_join(parts, ' ')
|
||||||
end
|
end
|
||||||
|
|
||||||
def procedure_modal_text(procedure, key)
|
def procedure_publish_text(procedure, key)
|
||||||
action = procedure.close? ? :reopen : :publish
|
action = procedure.close? ? :reopen : :publish
|
||||||
t(action, scope: [:modal, :publish, key])
|
t(action, scope: [:modal, :publish, key])
|
||||||
end
|
end
|
||||||
|
|
|
@ -23,7 +23,7 @@ import {
|
||||||
|
|
||||||
const Map = ReactMapboxGl({});
|
const Map = ReactMapboxGl({});
|
||||||
|
|
||||||
function MapEditor({ featureCollection, url, preview, hasCadastres, ign }) {
|
function MapEditor({ featureCollection, url, preview, options }) {
|
||||||
const drawControl = useRef(null);
|
const drawControl = useRef(null);
|
||||||
const [currentMap, setCurrentMap] = useState(null);
|
const [currentMap, setCurrentMap] = useState(null);
|
||||||
|
|
||||||
|
@ -35,10 +35,10 @@ function MapEditor({ featureCollection, url, preview, hasCadastres, ign }) {
|
||||||
const [cadastresFeatureCollection, setCadastresFeatureCollection] = useState(
|
const [cadastresFeatureCollection, setCadastresFeatureCollection] = useState(
|
||||||
filterFeatureCollection(featureCollection, 'cadastre')
|
filterFeatureCollection(featureCollection, 'cadastre')
|
||||||
);
|
);
|
||||||
const mapStyle = useMemo(() => getMapStyle(style, hasCadastres), [
|
const mapStyle = useMemo(
|
||||||
style,
|
() => getMapStyle(style, options.cadastres, options.mnhn),
|
||||||
hasCadastres
|
[style, options]
|
||||||
]);
|
);
|
||||||
|
|
||||||
const translations = [
|
const translations = [
|
||||||
['.mapbox-gl-draw_line', 'Tracer une ligne'],
|
['.mapbox-gl-draw_line', 'Tracer une ligne'],
|
||||||
|
@ -306,7 +306,7 @@ function MapEditor({ featureCollection, url, preview, hasCadastres, ign }) {
|
||||||
height: '500px'
|
height: '500px'
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
{hasCadastres ? (
|
{options.cadastres ? (
|
||||||
<GeoJSONLayer
|
<GeoJSONLayer
|
||||||
data={cadastresFeatureCollection}
|
data={cadastresFeatureCollection}
|
||||||
fillPaint={polygonCadastresFill}
|
fillPaint={polygonCadastresFill}
|
||||||
|
@ -326,7 +326,7 @@ function MapEditor({ featureCollection, url, preview, hasCadastres, ign }) {
|
||||||
trash: true
|
trash: true
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
<SwitchMapStyle style={style} setStyle={setStyle} ign={ign} />
|
<SwitchMapStyle style={style} setStyle={setStyle} ign={options.ign} />
|
||||||
<ZoomControl />
|
<ZoomControl />
|
||||||
</Map>
|
</Map>
|
||||||
</>
|
</>
|
||||||
|
@ -341,8 +341,11 @@ MapEditor.propTypes = {
|
||||||
}),
|
}),
|
||||||
url: PropTypes.string,
|
url: PropTypes.string,
|
||||||
preview: PropTypes.bool,
|
preview: PropTypes.bool,
|
||||||
hasCadastres: PropTypes.bool,
|
options: PropTypes.shape({
|
||||||
ign: PropTypes.bool
|
cadastres: PropTypes.bool,
|
||||||
|
mnhn: PropTypes.bool,
|
||||||
|
ign: PropTypes.bool
|
||||||
|
})
|
||||||
};
|
};
|
||||||
|
|
||||||
export default MapEditor;
|
export default MapEditor;
|
||||||
|
|
|
@ -16,7 +16,7 @@ import {
|
||||||
|
|
||||||
const Map = ReactMapboxGl({});
|
const Map = ReactMapboxGl({});
|
||||||
|
|
||||||
const MapReader = ({ featureCollection, ign }) => {
|
const MapReader = ({ featureCollection, options }) => {
|
||||||
const [currentMap, setCurrentMap] = useState(null);
|
const [currentMap, setCurrentMap] = useState(null);
|
||||||
const [style, setStyle] = useState('ortho');
|
const [style, setStyle] = useState('ortho');
|
||||||
const cadastresFeatureCollection = useMemo(
|
const cadastresFeatureCollection = useMemo(
|
||||||
|
@ -52,10 +52,10 @@ const MapReader = ({ featureCollection, ign }) => {
|
||||||
[selectionsUtilisateurFeatureCollection]
|
[selectionsUtilisateurFeatureCollection]
|
||||||
);
|
);
|
||||||
const hasCadastres = !!cadastresFeatureCollection.length;
|
const hasCadastres = !!cadastresFeatureCollection.length;
|
||||||
const mapStyle = useMemo(() => getMapStyle(style, hasCadastres), [
|
const mapStyle = useMemo(
|
||||||
style,
|
() => getMapStyle(style, hasCadastres, options.mnhn),
|
||||||
cadastresFeatureCollection
|
[style, options, cadastresFeatureCollection]
|
||||||
]);
|
);
|
||||||
const popup = useMemo(
|
const popup = useMemo(
|
||||||
() =>
|
() =>
|
||||||
new Popup({
|
new Popup({
|
||||||
|
@ -184,7 +184,7 @@ const MapReader = ({ featureCollection, ign }) => {
|
||||||
/>
|
/>
|
||||||
) : null}
|
) : null}
|
||||||
|
|
||||||
<SwitchMapStyle style={style} setStyle={setStyle} ign={ign} />
|
<SwitchMapStyle style={style} setStyle={setStyle} ign={options.ign} />
|
||||||
<ZoomControl />
|
<ZoomControl />
|
||||||
</Map>
|
</Map>
|
||||||
);
|
);
|
||||||
|
@ -196,7 +196,10 @@ MapReader.propTypes = {
|
||||||
bbox: PropTypes.array,
|
bbox: PropTypes.array,
|
||||||
features: PropTypes.array
|
features: PropTypes.array
|
||||||
}),
|
}),
|
||||||
ign: PropTypes.bool
|
options: PropTypes.shape({
|
||||||
|
ign: PropTypes.bool,
|
||||||
|
mnhn: PropTypes.bool
|
||||||
|
})
|
||||||
};
|
};
|
||||||
|
|
||||||
export default MapReader;
|
export default MapReader;
|
||||||
|
|
|
@ -1,15 +1,36 @@
|
||||||
|
const IGN_TOKEN = 'rc1egnbeoss72hxvd143tbyk';
|
||||||
|
|
||||||
|
function ignServiceURL(layer, format = 'image/png') {
|
||||||
|
const url = `https://wxs.ign.fr/${IGN_TOKEN}/geoportail/wmts`;
|
||||||
|
const query =
|
||||||
|
'service=WMTS&request=GetTile&version=1.0.0&tilematrixset=PM&tilematrix={z}&tilecol={x}&tilerow={y}&style=normal';
|
||||||
|
|
||||||
|
return `${url}?${query}&layer=${layer}&format=${format}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
function rasterSource(tiles, attribution) {
|
||||||
|
return {
|
||||||
|
type: 'raster',
|
||||||
|
tiles,
|
||||||
|
tileSize: 256,
|
||||||
|
attribution,
|
||||||
|
minzoom: 0,
|
||||||
|
maxzoom: 18
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
version: 8,
|
version: 8,
|
||||||
metadat: {
|
metadat: {
|
||||||
'mapbox:autocomposite': false,
|
'mapbox:autocomposite': false,
|
||||||
'mapbox:groups': {
|
'mapbox:groups': {
|
||||||
'1444849242106.713': { collapsed: false, name: 'Places' },
|
1444849242106.713: { collapsed: false, name: 'Places' },
|
||||||
'1444849334699.1902': { collapsed: true, name: 'Bridges' },
|
1444849334699.1902: { collapsed: true, name: 'Bridges' },
|
||||||
'1444849345966.4436': { collapsed: false, name: 'Roads' },
|
1444849345966.4436: { collapsed: false, name: 'Roads' },
|
||||||
'1444849354174.1904': { collapsed: true, name: 'Tunnels' },
|
1444849354174.1904: { collapsed: true, name: 'Tunnels' },
|
||||||
'1444849364238.8171': { collapsed: false, name: 'Buildings' },
|
1444849364238.8171: { collapsed: false, name: 'Buildings' },
|
||||||
'1444849382550.77': { collapsed: false, name: 'Water' },
|
1444849382550.77: { collapsed: false, name: 'Water' },
|
||||||
'1444849388993.3071': { collapsed: false, name: 'Land' }
|
1444849388993.3071: { collapsed: false, name: 'Land' }
|
||||||
},
|
},
|
||||||
'mapbox:type': 'template',
|
'mapbox:type': 'template',
|
||||||
'openmaptiles:mapbox:owner': 'openmaptiles',
|
'openmaptiles:mapbox:owner': 'openmaptiles',
|
||||||
|
@ -41,20 +62,34 @@ export default {
|
||||||
minzoom: 0,
|
minzoom: 0,
|
||||||
maxzoom: 19
|
maxzoom: 19
|
||||||
},
|
},
|
||||||
'carte-ign': {
|
|
||||||
type: 'raster',
|
|
||||||
tiles: [
|
|
||||||
'https://wxs.ign.fr/rc1egnbeoss72hxvd143tbyk/geoportail/wmts?service=WMTS&request=GetTile&version=1.0.0&tilematrixset=PM&tilematrix={z}&tilecol={x}&tilerow={y}&layer=GEOGRAPHICALGRIDSYSTEMS.MAPS&format=image/jpeg&style=normal'
|
|
||||||
],
|
|
||||||
tileSize: 256,
|
|
||||||
attribution: 'IGN-F/Géoportail',
|
|
||||||
minzoom: 0,
|
|
||||||
maxzoom: 18
|
|
||||||
},
|
|
||||||
cadastre: {
|
cadastre: {
|
||||||
type: 'vector',
|
type: 'vector',
|
||||||
url: 'https://openmaptiles.geo.data.gouv.fr/data/cadastre.json'
|
url: 'https://openmaptiles.geo.data.gouv.fr/data/cadastre.json'
|
||||||
}
|
},
|
||||||
|
'plan-ign': rasterSource(
|
||||||
|
[ignServiceURL('GEOGRAPHICALGRIDSYSTEMS.PLANIGNV2')],
|
||||||
|
'IGN-F/Géoportail'
|
||||||
|
),
|
||||||
|
'protectedareas-gp': rasterSource(
|
||||||
|
[ignServiceURL('PROTECTEDAREAS.GP')],
|
||||||
|
'IGN-F/Géoportail/MNHN'
|
||||||
|
),
|
||||||
|
'protectedareas-pn': rasterSource(
|
||||||
|
[ignServiceURL('PROTECTEDAREAS.PN')],
|
||||||
|
'IGN-F/Géoportail/MNHN'
|
||||||
|
),
|
||||||
|
'protectedareas-pnr': rasterSource(
|
||||||
|
[ignServiceURL('PROTECTEDAREAS.PNR')],
|
||||||
|
'IGN-F/Géoportail/MNHN'
|
||||||
|
),
|
||||||
|
'protectedareas-sic': rasterSource(
|
||||||
|
[ignServiceURL('PROTECTEDAREAS.SIC')],
|
||||||
|
'IGN-F/Géoportail/MNHN'
|
||||||
|
),
|
||||||
|
'protectedareas-zps': rasterSource(
|
||||||
|
[ignServiceURL('PROTECTEDAREAS.ZPS')],
|
||||||
|
'IGN-F/Géoportail/MNHN'
|
||||||
|
)
|
||||||
},
|
},
|
||||||
sprite: 'https://openmaptiles.github.io/osm-bright-gl-style/sprite',
|
sprite: 'https://openmaptiles.github.io/osm-bright-gl-style/sprite',
|
||||||
glyphs: 'https://openmaptiles.geo.data.gouv.fr/fonts/{fontstack}/{range}.pbf'
|
glyphs: 'https://openmaptiles.geo.data.gouv.fr/fonts/{fontstack}/{range}.pbf'
|
||||||
|
|
|
@ -3,16 +3,16 @@ import cadastre from './cadastre';
|
||||||
import orthoStyle from './ortho-style';
|
import orthoStyle from './ortho-style';
|
||||||
import vectorStyle from './vector-style';
|
import vectorStyle from './vector-style';
|
||||||
|
|
||||||
const ignStyle = [
|
function rasterStyle(source) {
|
||||||
{
|
return {
|
||||||
id: 'carte-ign',
|
id: source,
|
||||||
|
source,
|
||||||
type: 'raster',
|
type: 'raster',
|
||||||
source: 'carte-ign',
|
|
||||||
paint: { 'raster-resampling': 'linear' }
|
paint: { 'raster-resampling': 'linear' }
|
||||||
}
|
};
|
||||||
];
|
}
|
||||||
|
|
||||||
export function getMapStyle(style, hasCadastres) {
|
export function getMapStyle(style, hasCadastres, hasMNHN) {
|
||||||
const mapStyle = { ...baseStyle };
|
const mapStyle = { ...baseStyle };
|
||||||
|
|
||||||
switch (style) {
|
switch (style) {
|
||||||
|
@ -27,7 +27,7 @@ export function getMapStyle(style, hasCadastres) {
|
||||||
mapStyle.name = 'Carte OSM';
|
mapStyle.name = 'Carte OSM';
|
||||||
break;
|
break;
|
||||||
case 'ign':
|
case 'ign':
|
||||||
mapStyle.layers = ignStyle;
|
mapStyle.layers = [rasterStyle('plan-ign')];
|
||||||
mapStyle.id = 'ign';
|
mapStyle.id = 'ign';
|
||||||
mapStyle.name = 'Carte IGN';
|
mapStyle.name = 'Carte IGN';
|
||||||
break;
|
break;
|
||||||
|
@ -38,6 +38,17 @@ export function getMapStyle(style, hasCadastres) {
|
||||||
mapStyle.id += '-cadastre';
|
mapStyle.id += '-cadastre';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (hasMNHN) {
|
||||||
|
mapStyle.layers = mapStyle.layers.concat([
|
||||||
|
rasterStyle('protectedareas-gp'),
|
||||||
|
rasterStyle('protectedareas-pn'),
|
||||||
|
rasterStyle('protectedareas-pnr'),
|
||||||
|
rasterStyle('protectedareas-sic'),
|
||||||
|
rasterStyle('protectedareas-zps')
|
||||||
|
]);
|
||||||
|
mapStyle.id += '-mnhn';
|
||||||
|
}
|
||||||
|
|
||||||
return mapStyle;
|
return mapStyle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -140,6 +140,10 @@ const TypeDeChamp = sortableElement(
|
||||||
label="Cadastres"
|
label="Cadastres"
|
||||||
handler={updateHandlers.cadastres}
|
handler={updateHandlers.cadastres}
|
||||||
/>
|
/>
|
||||||
|
<TypeDeChampCarteOption
|
||||||
|
label="Zones naturelles protégées"
|
||||||
|
handler={updateHandlers.mnhn}
|
||||||
|
/>
|
||||||
</TypeDeChampCarteOptions>
|
</TypeDeChampCarteOptions>
|
||||||
<TypeDeChampRepetitionOptions
|
<TypeDeChampRepetitionOptions
|
||||||
isVisible={isRepetition}
|
isVisible={isRepetition}
|
||||||
|
@ -206,6 +210,7 @@ function createUpdateHandlers(dispatch, typeDeChamp, index, prefix) {
|
||||||
|
|
||||||
export const FIELDS = [
|
export const FIELDS = [
|
||||||
'cadastres',
|
'cadastres',
|
||||||
|
'mnhn',
|
||||||
'description',
|
'description',
|
||||||
'drop_down_list_value',
|
'drop_down_list_value',
|
||||||
'libelle',
|
'libelle',
|
||||||
|
|
|
@ -2,16 +2,21 @@ import { delegate } from '@utils';
|
||||||
|
|
||||||
delegate('click', 'body', (event) => {
|
delegate('click', 'body', (event) => {
|
||||||
if (!event.target.closest('.dropdown')) {
|
if (!event.target.closest('.dropdown')) {
|
||||||
[...document.querySelectorAll('.dropdown')].forEach((element) =>
|
[...document.querySelectorAll('.dropdown')].forEach((element) => {
|
||||||
element.classList.remove('open', 'fade-in-down')
|
const button = element.querySelector('.dropdown-button');
|
||||||
);
|
button.setAttribute('aria-expanded', false);
|
||||||
|
element.classList.remove('open', 'fade-in-down');
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
delegate('click', '.dropdown-button', (event) => {
|
delegate('click', '.dropdown-button', (event) => {
|
||||||
event.stopPropagation();
|
event.stopPropagation();
|
||||||
const parent = event.target.closest('.dropdown-button').parentElement;
|
const button = event.target.closest('.dropdown-button');
|
||||||
|
const parent = button.parentElement;
|
||||||
if (parent.classList.contains('dropdown')) {
|
if (parent.classList.contains('dropdown')) {
|
||||||
parent.classList.toggle('open');
|
parent.classList.toggle('open');
|
||||||
|
var buttonExpanded = button.getAttribute('aria-expanded') === 'true';
|
||||||
|
button.setAttribute('aria-expanded', !buttonExpanded);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -57,6 +57,18 @@ class Champs::CarteChamp < Champ
|
||||||
type_de_champ&.parcelles_agricoles && type_de_champ.parcelles_agricoles != '0'
|
type_de_champ&.parcelles_agricoles && type_de_champ.parcelles_agricoles != '0'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def mnhn?
|
||||||
|
type_de_champ&.mnhn && type_de_champ.mnhn != '0'
|
||||||
|
end
|
||||||
|
|
||||||
|
def render_options
|
||||||
|
{
|
||||||
|
ign: Flipper.enabled?(:carte_ign, procedure),
|
||||||
|
mnhn: mnhn?,
|
||||||
|
cadastres: cadastres?
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
def position
|
def position
|
||||||
if dossier.present?
|
if dossier.present?
|
||||||
dossier.geo_position
|
dossier.geo_position
|
||||||
|
|
|
@ -56,7 +56,7 @@ class TypeDeChamp < ApplicationRecord
|
||||||
belongs_to :parent, class_name: 'TypeDeChamp', optional: true
|
belongs_to :parent, class_name: 'TypeDeChamp', optional: true
|
||||||
has_many :types_de_champ, -> { ordered }, foreign_key: :parent_id, class_name: 'TypeDeChamp', inverse_of: :parent, dependent: :destroy
|
has_many :types_de_champ, -> { ordered }, foreign_key: :parent_id, class_name: 'TypeDeChamp', inverse_of: :parent, dependent: :destroy
|
||||||
|
|
||||||
store_accessor :options, :cadastres, :quartiers_prioritaires, :parcelles_agricoles, :old_pj, :drop_down_options, :skip_pj_validation
|
store_accessor :options, :cadastres, :quartiers_prioritaires, :parcelles_agricoles, :mnhn, :old_pj, :drop_down_options, :skip_pj_validation
|
||||||
has_many :revision_types_de_champ, class_name: 'ProcedureRevisionTypeDeChamp', dependent: :destroy, inverse_of: :type_de_champ
|
has_many :revision_types_de_champ, class_name: 'ProcedureRevisionTypeDeChamp', dependent: :destroy, inverse_of: :type_de_champ
|
||||||
|
|
||||||
delegate :tags_for_template, to: :dynamic_type
|
delegate :tags_for_template, to: :dynamic_type
|
||||||
|
@ -286,12 +286,11 @@ class TypeDeChamp < ApplicationRecord
|
||||||
:updated_at
|
:updated_at
|
||||||
],
|
],
|
||||||
methods: [
|
methods: [
|
||||||
:cadastres,
|
|
||||||
:drop_down_list_value,
|
:drop_down_list_value,
|
||||||
:parcelles_agricoles,
|
|
||||||
:piece_justificative_template_filename,
|
:piece_justificative_template_filename,
|
||||||
:piece_justificative_template_url,
|
:piece_justificative_template_url,
|
||||||
:quartiers_prioritaires
|
:cadastres,
|
||||||
|
:mnhn
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
TYPES_DE_CHAMP = TYPES_DE_CHAMP_BASE
|
TYPES_DE_CHAMP = TYPES_DE_CHAMP_BASE
|
||||||
|
|
|
@ -1,38 +0,0 @@
|
||||||
- if smart_listing.present?
|
|
||||||
%table.table#dossiers-list
|
|
||||||
%thead
|
|
||||||
%th#ID= smart_listing.sortable 'ID', 'id'
|
|
||||||
%th#libelle= smart_listing.sortable 'Libellé', 'libelle'
|
|
||||||
- if @active_class
|
|
||||||
%th Lien
|
|
||||||
- if @active_class || @archived_class
|
|
||||||
%th#published_at= smart_listing.sortable 'Date publication', 'published_at'
|
|
||||||
- else
|
|
||||||
%th#created_at= smart_listing.sortable 'Date création', 'created_at'
|
|
||||||
%th Actions
|
|
||||||
|
|
||||||
- @procedures.each do |procedure|
|
|
||||||
- procedure = procedure
|
|
||||||
- admin_procedure_href = admin_procedure_path(procedure)
|
|
||||||
%tr{ id: "tr_dossier_#{procedure.id}", data: { href: admin_procedure_href } }
|
|
||||||
%td= link_to(procedure.id, admin_procedure_href)
|
|
||||||
%td.col-xs-6= link_to(procedure.libelle, admin_procedure_href)
|
|
||||||
- if procedure.publiee?
|
|
||||||
%td.procedure-lien= link_to(procedure_lien(procedure), procedure_lien(procedure))
|
|
||||||
- if procedure.locked?
|
|
||||||
%td= link_to(procedure.published_at.present? ? try_format_datetime(procedure.published_at) : "", admin_procedure_href)
|
|
||||||
- else
|
|
||||||
%td= link_to(try_format_datetime(procedure.created_at), admin_procedure_href)
|
|
||||||
%td
|
|
||||||
= link_to('Cloner', admin_procedure_clone_path(procedure.id), data: { method: :put }, class: 'btn-sm btn-primary clone-btn')
|
|
||||||
- if procedure.can_be_deleted_by_administrateur?
|
|
||||||
= link_to('X', url_for(controller: 'admin/procedures', action: :destroy, id: procedure.id), data: { method: :delete, confirm: "Confirmez-vous la suppression de la démarche ? \n\n Attention : toute suppression est définitive et s’appliquera aux éventuels autres administrateurs de cette démarche !" }, class: 'btn-sm btn-danger')
|
|
||||||
|
|
||||||
= smart_listing.paginate
|
|
||||||
= smart_listing.pagination_per_page_links
|
|
||||||
%br
|
|
||||||
|
|
||||||
|
|
||||||
- else
|
|
||||||
%h4.center
|
|
||||||
Aucune démarche
|
|
|
@ -1,49 +0,0 @@
|
||||||
#publish-modal.modal{ "aria-labelledby" => "myModalLabel", :role => "dialog", :tabindex => "-1" }
|
|
||||||
.modal-dialog.modal-lg{ :role => "document" }
|
|
||||||
= form_tag admin_procedure_publish_path(procedure_id: procedure.id), method: :put, remote: true do
|
|
||||||
.modal-content
|
|
||||||
.modal-header
|
|
||||||
%button.close{ "aria-label" => "Close", "data-dismiss" => "modal", :type => "button" }
|
|
||||||
%span{ "aria-hidden" => "true" } ×
|
|
||||||
%h4#myModalLabel.modal-title
|
|
||||||
= procedure_modal_text(procedure, :title)
|
|
||||||
%span#publish-modal-title
|
|
||||||
.modal-body
|
|
||||||
.text-info
|
|
||||||
%p
|
|
||||||
= procedure_modal_text(procedure, :body)
|
|
||||||
%b Elle ne pourra plus être modifiée à l’issue de cette publication.
|
|
||||||
.form-group
|
|
||||||
%h4 Adresse de la démarche
|
|
||||||
%p Vous pouvez personnaliser le lien public de la démarche pour en faciliter l’accès.
|
|
||||||
%p
|
|
||||||
= commencer_url(path: '')
|
|
||||||
= text_field_tag(:path, procedure.path,
|
|
||||||
id: 'procedure_path',
|
|
||||||
placeholder: 'chemin-de-la-démarche',
|
|
||||||
required: true,
|
|
||||||
class: 'form-control',
|
|
||||||
pattern: '^[a-z0-9_-]{3,50}$',
|
|
||||||
title: "De 3 à 50 caractères; minuscules, chiffres et tiret seulement",
|
|
||||||
data: { remote: true, debounce: true, url: admin_procedure_publish_validate_path(procedure) },
|
|
||||||
autocomplete: 'off',
|
|
||||||
style: 'width: 300px; display: inline;')
|
|
||||||
= render 'publish_path_message', procedure: procedure, administrateur: administrateur
|
|
||||||
.text-info
|
|
||||||
Attention, diffusez toujours le <strong>lien complet</strong> affiché ci-dessus, et non pas un lien générique vers #{APPLICATION_NAME}. Ne dites pas non plus aux usagers de se rendre sur le site générique #{APPLICATION_NAME}, donnez-leur toujours le lien complet.
|
|
||||||
.form-group
|
|
||||||
%h4 Diffusion de la démarche
|
|
||||||
%p Où les utilisateurs trouveront-ils le lien de la démarche ? Typiquement, il s’agit d’une page de votre site web.
|
|
||||||
%p.center
|
|
||||||
= text_field_tag(:lien_site_web, procedure.lien_site_web,
|
|
||||||
required: true,
|
|
||||||
class: 'form-control',
|
|
||||||
autocomplete: 'off',
|
|
||||||
placeholder: 'https://exemple.gouv.fr/ma_demarche')
|
|
||||||
.text-info
|
|
||||||
Prenez quelques minutes pour savoir comment établir une bonne relation avec les usagers de votre démarche :
|
|
||||||
= link_to "Regarder la vidéo de 5 minutes.",
|
|
||||||
"https://vimeo.com/334463514",
|
|
||||||
target: "_blank"
|
|
||||||
.modal-footer
|
|
||||||
= render 'publish_buttons', procedure: procedure, administrateur: administrateur
|
|
|
@ -1,27 +0,0 @@
|
||||||
#transfer-modal.modal.fade{ "aria-labelledby" => "TransferProcedureModal", :role => "dialog", :tabindex => "-1" }
|
|
||||||
.modal-dialog.modal-md{ :role => "document" }
|
|
||||||
= form_tag admin_procedure_transfer_path(procedure_id: @procedure.id), method: :post, remote: true do
|
|
||||||
.modal-content
|
|
||||||
.modal-header
|
|
||||||
%button.close{ "aria-label" => "Close", "data-dismiss" => "modal", :type => "button" }
|
|
||||||
%span{ "aria-hidden" => "true" } ×
|
|
||||||
|
|
||||||
%h4#myModalLabel.modal-title
|
|
||||||
Envoyer une copie de cette démarche à un autre administrateur
|
|
||||||
|
|
||||||
.modal-body
|
|
||||||
%p
|
|
||||||
Cette fonctionnalité vous permet de d'envoyer une copie de votre démarche à un autre administrateur.
|
|
||||||
|
|
||||||
%div{ style:'margin-top:20px' }
|
|
||||||
= text_field_tag :email_admin, '', { class: 'form-control',
|
|
||||||
type: 'email',
|
|
||||||
placeholder: 'Email administrateur cible',
|
|
||||||
style: 'width: 300px; margin-left:auto; margin-right:auto' }
|
|
||||||
|
|
||||||
#not_found_admin.center.text-danger{ style:'display: none; margin-top: 10px;' }
|
|
||||||
Cet administrateur n'existe pas.
|
|
||||||
|
|
||||||
.modal-footer
|
|
||||||
= submit_tag "Envoyer", class: 'btn btn-success'
|
|
||||||
= button_tag 'Annuler', class: %w(btn btn btn-default), id: 'cancel', data: { dismiss: 'modal' }
|
|
|
@ -1,17 +0,0 @@
|
||||||
#onglets
|
|
||||||
%ul.nav.nav-tabs
|
|
||||||
%li{ class: @draft_class }
|
|
||||||
%a{ :href => "#{url_for :admin_procedures_draft}" }
|
|
||||||
%h5.text-primary
|
|
||||||
En test
|
|
||||||
|
|
||||||
%li{ class: @active_class }
|
|
||||||
%a{ :href => "#{url_for :admin_procedures}" }
|
|
||||||
%h5.text-success
|
|
||||||
Actives
|
|
||||||
|
|
||||||
%li{ class: @archived_class }
|
|
||||||
%a{ :href => "#{url_for :admin_procedures_archived}" }
|
|
||||||
%h5{ style: 'color: black;' }
|
|
||||||
Closes
|
|
||||||
%br
|
|
|
@ -1,13 +0,0 @@
|
||||||
#publish-buttons
|
|
||||||
= button_tag "Annuler", class: %w(btn btn-default), data: { dismiss: :modal }
|
|
||||||
|
|
||||||
- procedure.validate(:publication)
|
|
||||||
- errors = procedure.errors
|
|
||||||
-# Ignore the :taken error if the path can be claimed
|
|
||||||
- if errors.details[:path]&.pluck(:error)&.include?(:taken) && procedure.path_available?(administrateur, procedure.path)
|
|
||||||
- errors.delete(:path)
|
|
||||||
|
|
||||||
- options = { class: %w(btn btn-success), id: 'publish' }
|
|
||||||
- if errors.details[:path].present?
|
|
||||||
- options[:disabled] = :disabled
|
|
||||||
= submit_tag procedure_modal_text(@procedure, :submit), options
|
|
|
@ -1,11 +0,0 @@
|
||||||
#publish-path-message
|
|
||||||
- procedure.validate(:publication)
|
|
||||||
- errors = procedure.errors
|
|
||||||
-# Ignore the :taken error if the path can be claimed, and instead display the :taken_can_be_claimed error message.
|
|
||||||
- if errors.details[:path]&.pluck(:error)&.include?(:taken) && procedure.path_available?(administrateur, procedure.path)
|
|
||||||
.alert.alert-warning
|
|
||||||
= errors.full_message('Le lien public', errors.generate_message(:path, :taken_can_be_claimed))
|
|
||||||
- elsif errors.messages[:path].present?
|
|
||||||
-# Display the actual errors for :path
|
|
||||||
.alert.alert-danger
|
|
||||||
= errors.full_message('Le lien public', errors.messages[:path].first)
|
|
|
@ -1,14 +0,0 @@
|
||||||
#admins-index
|
|
||||||
.default-data-block.default_visible
|
|
||||||
.row.show-block#new_dossiers
|
|
||||||
.header
|
|
||||||
.col-lg-10.col-md-10.col-sm-10.col-xs-10.title
|
|
||||||
.carret-right
|
|
||||||
.carret-down
|
|
||||||
Démarches
|
|
||||||
%a{ href: new_from_existing_admin_procedures_path }
|
|
||||||
#new-procedure.col-lg-2.col-md-2.col-sm-2.col-xs-2.action
|
|
||||||
Nouvelle
|
|
||||||
|
|
||||||
.body
|
|
||||||
= smart_listing_render :procedures
|
|
|
@ -1 +0,0 @@
|
||||||
<%= smart_listing_update :procedures %>
|
|
|
@ -1,4 +0,0 @@
|
||||||
= render_to_element("#publish-path-message", partial: 'publish_path_message', outer: true,
|
|
||||||
locals: { procedure: @procedure, administrateur: current_administrateur })
|
|
||||||
= render_to_element("#publish-buttons", partial: 'publish_buttons', outer: true,
|
|
||||||
locals: { procedure: @procedure, administrateur: current_administrateur })
|
|
|
@ -1,128 +0,0 @@
|
||||||
= render partial: 'admin/closed_mail_template_attestation_inconsistency_alert'
|
|
||||||
.row.white-back
|
|
||||||
= render 'modal_publish', procedure: @procedure, administrateur: @current_administrateur
|
|
||||||
= render 'modal_transfer'
|
|
||||||
|
|
||||||
#procedure_show
|
|
||||||
- if @procedure.brouillon?
|
|
||||||
- if @procedure.missing_steps.present?
|
|
||||||
- missing_elements = []
|
|
||||||
- if @procedure.missing_instructeurs?
|
|
||||||
- missing_elements << 'des instructeurs'
|
|
||||||
- if @procedure.service.nil?
|
|
||||||
- missing_elements << 'un service'
|
|
||||||
- message = "Affectez #{missing_elements.join(' et ')} à votre démarche."
|
|
||||||
%button.action_button.btn.btn-success#disabled-publish-procedure{ style: 'float: right; margin-top: 10px;', disabled: true, title: message }
|
|
||||||
%i.fa.fa-eraser
|
|
||||||
Publier
|
|
||||||
- else
|
|
||||||
%button.btn.btn-success#publish-procedure{ data: { target: '#publish-modal', toggle: :modal }, type: 'button', style: 'float: right; margin-top: 10px;' }
|
|
||||||
%i.fa.fa-eraser
|
|
||||||
Publier
|
|
||||||
|
|
||||||
%button.btn.btn-default#transfer-procedure{ data: { target: '#transfer-modal', toggle: :modal }, type: 'button', style: 'float: right; margin-top: 10px; margin-right: 10px;' }
|
|
||||||
%i.fa.fa-exchange
|
|
||||||
Envoyer une copie
|
|
||||||
|
|
||||||
- if @procedure.close? || @procedure.depubliee?
|
|
||||||
%button.btn.btn-default#reopen-procedure{ data: { target: '#publish-modal', toggle: :modal }, type: 'button', style: 'float: right; margin-top: 10px; margin-right: 10px;' }
|
|
||||||
%i.fa.fa-rocket
|
|
||||||
Réactiver
|
|
||||||
|
|
||||||
- elsif @procedure.publiee?
|
|
||||||
= form_tag admin_procedure_archive_path(procedure_id: @procedure.id), method: :put, style: 'float: right; margin-top: 10px;' do
|
|
||||||
%button#archive-procedure.btn.btn-small.btn-default.text-info{ type: :button }
|
|
||||||
%i.fa.fa-eraser
|
|
||||||
Archiver
|
|
||||||
#confirm
|
|
||||||
%button#valid.btn.btn-small.btn-success{ type: :submit }
|
|
||||||
%i.fa.fa-check
|
|
||||||
Valider
|
|
||||||
%button#cancel.btn.btn-small.btn-danger{ type: :button }
|
|
||||||
%i.fa.fa-remove
|
|
||||||
Annuler
|
|
||||||
|
|
||||||
.lien-demarche
|
|
||||||
%h3
|
|
||||||
- if @procedure.brouillon?
|
|
||||||
Test et publication
|
|
||||||
- else
|
|
||||||
Publication
|
|
||||||
%div{ style: 'margin-top: 30px;' }
|
|
||||||
- if @procedure.close?
|
|
||||||
Cette démarche est <strong>close</strong> et n’est donc plus accessible par le public.
|
|
||||||
- elsif @procedure.publiee?
|
|
||||||
Cette démarche est <strong>publiée</strong>, certains éléments ne peuvent plus être modifiés.
|
|
||||||
Pour y accéder vous pouvez utiliser le lien :
|
|
||||||
= link_to @procedure_lien, sanitize_url(@procedure_lien), target: :blank, rel: :noopener
|
|
||||||
%br
|
|
||||||
%br
|
|
||||||
Attention, diffusez toujours le <strong>lien complet</strong> affiché ci-dessus, et non pas un lien générique vers #{APPLICATION_NAME}. Ne dites pas non plus aux usagers de se rendre sur le site générique #{APPLICATION_NAME}, donnez-leur toujours le lien complet.
|
|
||||||
- elsif @procedure.brouillon?
|
|
||||||
- if @procedure.missing_steps.empty?
|
|
||||||
%p
|
|
||||||
Cette démarche est actuellement <strong>en test</strong>,
|
|
||||||
pour y accéder vous pouvez utiliser le lien :
|
|
||||||
= link_to @procedure_lien, sanitize_url(@procedure_lien), target: :blank, rel: :noopener
|
|
||||||
%p
|
|
||||||
Toute personne ayant la connaissance de ce lien pourra ainsi remplir des dossiers de test sur votre démarche.
|
|
||||||
%br
|
|
||||||
%h4 Protection des Données personnelles
|
|
||||||
%p
|
|
||||||
À ce moment du processus de création, vous devez informer votre Délégué à la Protection des Données personnelles (DPD).
|
|
||||||
(
|
|
||||||
%a{ href:'https://www.cnil.fr/fr/protection-des-donnees-les-bons-reflexes', target:'_blank' }
|
|
||||||
https://www.cnil.fr/fr/protection-des-donnees-les-bons-reflexes
|
|
||||||
)
|
|
||||||
Si votre démarche propose de collecter des données personnelles, vous devez informer votre DPD. Chaque organisme en a un.
|
|
||||||
%p
|
|
||||||
Ce dernier pourra vous aider dans la finalisation de votre démarche, et vous inviter à vous interroger sur les données collectées, et sur la pertinence de ses dernières.
|
|
||||||
N'oubliez pas : toutes les démarches qui contiennent des données personnelles doivent être consignées dans un registre des traitements :
|
|
||||||
%a{ href:'https://www.cnil.fr/fr/RGDP-le-registre-des-activites-de-traitement', target:'_blank' }
|
|
||||||
https://www.cnil.fr/fr/RGDP-le-registre-des-activites-de-traitement
|
|
||||||
%p
|
|
||||||
Comment faire :
|
|
||||||
vous pouvez soit lui communiquer par email le lien vers la démarche en test, ou bien le nommer « administrateur ». Dans tous les cas, ne publiez votre démarche qu’après avoir eu son avis.
|
|
||||||
|
|
||||||
%br
|
|
||||||
%h4 Ce que vous pouvez faire lorsque vous êtes en test
|
|
||||||
%p
|
|
||||||
Profitez de la phase de test pour tester la saisie de dossiers, ainsi que toutes les fonctionnalités associées (instruction, emails automatiques, attestations, etc.).
|
|
||||||
%p
|
|
||||||
Vous pouvez effectuer toutes les modifications que vous souhaitez sur votre démarche pendant cette phase de test.
|
|
||||||
%p
|
|
||||||
Les dossiers qui seront remplis pendant la phase de test seront automatiquement supprimés lors de la modification ou la publication de votre démarche.
|
|
||||||
%br
|
|
||||||
|
|
||||||
%h4 Ce qui se passe lorsque vous passez en publication
|
|
||||||
%p
|
|
||||||
Une fois que vous êtes prêt à publier définitivement votre démarche, cliquez sur le bouton "Publier" pour choisir le lien définitif de votre démarche, les modifications sur la démarches ne seront alors plus possibles.
|
|
||||||
|
|
||||||
%br
|
|
||||||
%h4 Prenez quelques minutes pour savoir comment établir une bonne relation avec les usagers de votre démarche:
|
|
||||||
%p.center
|
|
||||||
%br
|
|
||||||
%iframe{ :src =>"https://player.vimeo.com/video/334463514?color=0069CC",:width =>"640",:height =>"360",:frameborder => "0" }
|
|
||||||
- else
|
|
||||||
.alert.alert-info
|
|
||||||
Pour pouvoir tester cette démarche, vous devez d’abord lui affecter
|
|
||||||
- if @procedure.missing_instructeurs?
|
|
||||||
= link_to("des instructeurs", admin_procedure_groupe_instructeur_path(@procedure, @procedure.defaut_groupe_instructeur))
|
|
||||||
- if @procedure.missing_instructeurs? && @procedure.service.nil?
|
|
||||||
et
|
|
||||||
- if @procedure.service.nil?
|
|
||||||
= link_to("un service", admin_services_path(procedure_id: @procedure))
|
|
||||||
\.
|
|
||||||
- else
|
|
||||||
- if @procedure.missing_steps.include?(:service)
|
|
||||||
%p.alert.alert-danger
|
|
||||||
Vous devez renseigner les coordonnées de votre Service administratif avant de pouvoir publier votre démarche.
|
|
||||||
= link_to 'Cliquez ici.', (@current_administrateur.services.present? ? url_for(admin_services_path(procedure_id: @procedure.id)) : url_for(new_admin_service_path(procedure_id: @procedure.id)))
|
|
||||||
|
|
||||||
- if @procedure.missing_steps.include?(:instructeurs)
|
|
||||||
%p.alert.alert-danger
|
|
||||||
Vous devez affecter des instructeurs avant de pouvoir publier votre démarche.
|
|
||||||
= link_to 'Cliquez ici.', admin_procedure_groupe_instructeur_path(@procedure, @procedure.defaut_groupe_instructeur)
|
|
||||||
|
|
||||||
%p.alert.alert-info
|
|
||||||
Cette démarche n’a pas encore de lien, et n’est pas accessible par le public.
|
|
|
@ -1,10 +0,0 @@
|
||||||
<%- if response.status == 404 %>
|
|
||||||
$('#not_found_admin').slideDown(100);
|
|
||||||
<%- else %>
|
|
||||||
<%= render_flash %>
|
|
||||||
|
|
||||||
$('#not_found_admin').slideUp(100);
|
|
||||||
$("#email_admin").val('');
|
|
||||||
|
|
||||||
$('[role=dialog]').modal('hide');
|
|
||||||
<%- end %>
|
|
|
@ -1,7 +1,7 @@
|
||||||
%span.dropdown.print-menu-opener
|
%span.dropdown.print-menu-opener
|
||||||
%button.button.dropdown-button.icon-only{ title: 'imprimer', 'aria-label': 'imprimer' }
|
%button.button.dropdown-button.icon-only{ title: 'imprimer', 'aria-label': 'imprimer', 'aria-expanded' => 'false', 'aria-controls' => 'print-menu' }
|
||||||
%span.icon.printer
|
%span.icon.printer
|
||||||
%ul.print-menu.dropdown-content
|
%ul#print-menu.print-menu.dropdown-content
|
||||||
%li
|
%li
|
||||||
= link_to "Tout le dossier", print_instructeur_dossier_path(dossier.procedure, dossier), target: "_blank", rel: "noopener", class: "menu-item menu-link"
|
= link_to "Tout le dossier", print_instructeur_dossier_path(dossier.procedure, dossier), target: "_blank", rel: "noopener", class: "menu-item menu-link"
|
||||||
%li
|
%li
|
||||||
|
@ -14,9 +14,9 @@
|
||||||
|
|
||||||
- if PiecesJustificativesService.liste_pieces_justificatives(dossier).present?
|
- if PiecesJustificativesService.liste_pieces_justificatives(dossier).present?
|
||||||
%span.dropdown.print-menu-opener
|
%span.dropdown.print-menu-opener
|
||||||
%button.button.dropdown-button.icon-only
|
%button.button.dropdown-button.icon-only{ 'aria-expanded' => 'false', 'aria-controls' => 'print-pj-menu' }
|
||||||
%span.icon.attached
|
%span.icon.attached
|
||||||
%ul.print-menu.dropdown-content
|
%ul#print-pj-menu.print-menu.dropdown-content
|
||||||
%li
|
%li
|
||||||
- if PiecesJustificativesService.pieces_justificatives_total_size(dossier) < Dossier::TAILLE_MAX_ZIP
|
- if PiecesJustificativesService.pieces_justificatives_total_size(dossier) < Dossier::TAILLE_MAX_ZIP
|
||||||
= link_to "Télécharger toutes les pièces jointes", telecharger_pjs_instructeur_dossier_path(dossier.procedure, dossier), target: "_blank", rel: "noopener", class: "menu-item menu-link"
|
= link_to "Télécharger toutes les pièces jointes", telecharger_pjs_instructeur_dossier_path(dossier.procedure, dossier), target: "_blank", rel: "noopener", class: "menu-item menu-link"
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
.dropdown
|
.dropdown
|
||||||
-# Dropdown button title
|
-# Dropdown button title
|
||||||
%button.button.primary.dropdown-button{ class: button_or_label_class(dossier) }
|
%button.button.primary.dropdown-button{ class: button_or_label_class(dossier), 'aria-expanded' => 'false', 'aria-controls' => 'state-menu' }
|
||||||
= dossier_display_state dossier
|
= dossier_display_state dossier
|
||||||
|
|
||||||
-# Dropdown content
|
-# Dropdown content
|
||||||
.dropdown-content.fade-in-down
|
#state-menu.dropdown-content.fade-in-down
|
||||||
|
|
||||||
- if dossier.en_construction?
|
- if dossier.en_construction?
|
||||||
-# ------------------------------------------------------
|
-# ------------------------------------------------------
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
- if procedure.dossiers.state_not_brouillon.any?
|
- if procedure.dossiers.state_not_brouillon.any?
|
||||||
%span.dropdown
|
%span.dropdown
|
||||||
%button.button.dropdown-button
|
%button.button.dropdown-button{ 'aria-expanded' => 'false', 'aria-controls' => 'download-menu' }
|
||||||
Télécharger tous les dossiers
|
Télécharger tous les dossiers
|
||||||
.dropdown-content.fade-in-down{ style: 'width: 330px' }
|
#download-menu.dropdown-content.fade-in-down{ style: 'width: 330px' }
|
||||||
%ul.dropdown-items
|
%ul.dropdown-items
|
||||||
- [[xlsx_export, :xlsx], [ods_export, :ods], [csv_export, :csv]].each do |(export, format)|
|
- [[xlsx_export, :xlsx], [ods_export, :ods], [csv_export, :csv]].each do |(export, format)|
|
||||||
%li
|
%li
|
||||||
|
|
|
@ -78,9 +78,9 @@
|
||||||
- if @dossiers.present? || @current_filters.count > 0
|
- if @dossiers.present? || @current_filters.count > 0
|
||||||
= paginate @dossiers
|
= paginate @dossiers
|
||||||
%span.dropdown
|
%span.dropdown
|
||||||
%button.button.dropdown-button
|
%button.button.dropdown-button{ 'aria-expanded' => 'false', 'aria-controls' => 'filter-menu' }
|
||||||
Filtrer
|
Filtrer
|
||||||
.dropdown-content.left-aligned.fade-in-down
|
#filter-menu.dropdown-content.left-aligned.fade-in-down
|
||||||
= form_tag add_filter_instructeur_procedure_path(@procedure), method: :post, class: 'dropdown-form large' do
|
= form_tag add_filter_instructeur_procedure_path(@procedure), method: :post, class: 'dropdown-form large' do
|
||||||
= label_tag :field, "Colonne"
|
= label_tag :field, "Colonne"
|
||||||
= select_tag :field, options_for_select(@available_fields_to_filters)
|
= select_tag :field, options_for_select(@available_fields_to_filters)
|
||||||
|
@ -118,9 +118,9 @@
|
||||||
|
|
||||||
%th.action-col.follow-col
|
%th.action-col.follow-col
|
||||||
%span.dropdown
|
%span.dropdown
|
||||||
%button.button.dropdown-button
|
%button.button.dropdown-button{ 'aria-expanded' => 'false', 'aria-controls' => 'custom-menu' }
|
||||||
Personnaliser
|
Personnaliser
|
||||||
.dropdown-content.fade-in-down
|
#custom-menu.dropdown-content.fade-in-down
|
||||||
= form_tag update_displayed_fields_instructeur_procedure_path(@procedure), method: :patch, class: 'dropdown-form columns-form' do
|
= form_tag update_displayed_fields_instructeur_procedure_path(@procedure), method: :patch, class: 'dropdown-form columns-form' do
|
||||||
= select_tag :values,
|
= select_tag :values,
|
||||||
options_for_select(@procedure_presentation.fields_for_select,
|
options_for_select(@procedure_presentation.fields_for_select,
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
.dropdown.invite-user-action
|
.dropdown.invite-user-action
|
||||||
%button.button.dropdown-button
|
%button.button.dropdown-button{ 'aria-expanded' => 'false', 'aria-controls' => 'invite-content' }
|
||||||
%span.icon.person
|
%span.icon.person
|
||||||
- if dossier.invites.count > 0
|
- if dossier.invites.count > 0
|
||||||
Voir les personnes invitées
|
Voir les personnes invitées
|
||||||
|
@ -10,5 +10,5 @@
|
||||||
- else
|
- else
|
||||||
Inviter une personne à modifier ce dossier
|
Inviter une personne à modifier ce dossier
|
||||||
|
|
||||||
.dropdown-content.fade-in-down
|
#invite-content.dropdown-content.fade-in-down
|
||||||
= render partial: "invites/form", locals: { dossier: dossier }
|
= render partial: "invites/form", locals: { dossier: dossier }
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
.dropdown.header-menu-opener
|
.dropdown.header-menu-opener
|
||||||
%button.button.dropdown-button.header-menu-button{ title: "Mon compte" }
|
%button.button.dropdown-button.icon-only.header-menu-button{ title: "Mon compte", 'aria-expanded' => 'false', 'aria-controls' => 'mon_compte_menu' }
|
||||||
.hidden Mon compte
|
.hidden Mon compte
|
||||||
= image_tag "icons/account-circle.svg", alt: ''
|
= image_tag "icons/account-circle.svg", alt: 'Mon compte'
|
||||||
%ul.header-menu.dropdown-content
|
%ul.header-menu.dropdown-content#mon_compte_menu
|
||||||
%li
|
%li
|
||||||
.menu-item{ title: current_email }
|
.menu-item{ title: current_email }
|
||||||
= current_email
|
= current_email
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
- content_for(:root_class, 'scroll-margins-for-sticky-footer')
|
||||||
- if params[:id] == 'closed_mail'
|
- if params[:id] == 'closed_mail'
|
||||||
= render partial: 'admin/closed_mail_template_attestation_inconsistency_alert'
|
= render partial: 'admin/closed_mail_template_attestation_inconsistency_alert'
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,13 @@
|
||||||
|
= form_tag admin_procedure_transfer_path(procedure_id: @procedure.id), method: :post, class: 'form' do
|
||||||
|
.card
|
||||||
|
%h2.card-title
|
||||||
|
Envoyer une copie de cette démarche à un autre administrateur
|
||||||
|
%p.mb-4
|
||||||
|
Cette fonctionnalité vous permet de d'envoyer une copie de votre démarche à un autre administrateur.
|
||||||
|
|
||||||
|
%div
|
||||||
|
= text_field_tag :email_admin, '', { class: 'form-control',
|
||||||
|
type: 'email',
|
||||||
|
placeholder: 'Email administrateur cible' }
|
||||||
|
|
||||||
|
= submit_tag "Envoyer à l'administrateur", class: 'button primary'
|
|
@ -33,9 +33,9 @@
|
||||||
%span.icon.edit
|
%span.icon.edit
|
||||||
Modifier
|
Modifier
|
||||||
.dropdown
|
.dropdown
|
||||||
.button.dropdown-button.procedures-actions-btn
|
.button.dropdown-button.procedures-actions-btn{ 'aria-expanded' => 'false', 'aria-controls' => 'actions-menu' }
|
||||||
Actions
|
Actions
|
||||||
.dropdown-content.fade-in-down
|
#actions-menu.dropdown-content.fade-in-down
|
||||||
%ul.dropdown-items.pl-0
|
%ul.dropdown-items.pl-0
|
||||||
- if !procedure.close?
|
- if !procedure.close?
|
||||||
%li
|
%li
|
||||||
|
@ -63,11 +63,3 @@
|
||||||
%span.icon.refuse
|
%span.icon.refuse
|
||||||
.dropdown-description
|
.dropdown-description
|
||||||
%h4 Supprimer
|
%h4 Supprimer
|
||||||
|
|
||||||
- if procedure.close?
|
|
||||||
%li
|
|
||||||
= link_to admin_procedure_publication_path(procedure) do
|
|
||||||
%span.icon.unarchive
|
|
||||||
.dropdown-description
|
|
||||||
%h4 Réactiver
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,40 @@
|
||||||
|
.card.mb-4
|
||||||
|
%h2.card-title Publiez votre démarche
|
||||||
|
= form_tag admin_procedure_publish_path(procedure_id: procedure.id), method: :put, class: 'form' do
|
||||||
|
%p.mb-4 Publiez votre démarche, et partagez la à vos usagers. Aucune modification ne sera possible.
|
||||||
|
%p Personnalisez le lien public de la démarche pour en faciliter l’accès (<strong>obligatoire pour publier votre démarche</strong>) :
|
||||||
|
%p.empty-text
|
||||||
|
= commencer_url(path: '')
|
||||||
|
= text_field_tag(:path, procedure.path,
|
||||||
|
id: 'procedure_path',
|
||||||
|
label: 'Adresse de diffusion',
|
||||||
|
placeholder: 'chemin-de-la-démarche',
|
||||||
|
required: true,
|
||||||
|
class: 'form',
|
||||||
|
pattern: '^[a-z0-9_-]{3,50}$',
|
||||||
|
title: "De 3 à 50 caractères; minuscules, chiffres et tiret seulement",
|
||||||
|
data: { debounce: true, url: admin_procedure_publish_validate_path(procedure)},
|
||||||
|
autocomplete: 'off',
|
||||||
|
style: 'width: 300px; display: inline;')
|
||||||
|
.text-info.mb-4
|
||||||
|
Attention, diffusez toujours le <strong>lien complet</strong> affiché ci-dessus, et non pas un lien générique vers #{APPLICATION_NAME}. Ne dites pas non plus aux usagers de se rendre sur le site générique #{APPLICATION_NAME}, donnez-leur toujours le lien complet.
|
||||||
|
%h2.card-title Diffusion de la démarche
|
||||||
|
%p Où les utilisateurs trouveront-ils le lien de la démarche ? Typiquement, il s’agit d’une page de votre site web.
|
||||||
|
%p.center
|
||||||
|
= text_field_tag(:lien_site_web, procedure.lien_site_web,
|
||||||
|
required: true,
|
||||||
|
class: 'form-control',
|
||||||
|
autocomplete: 'off',
|
||||||
|
placeholder: 'https://exemple.gouv.fr/ma_demarche')
|
||||||
|
|
||||||
|
- procedure.validate(:publication)
|
||||||
|
- errors = procedure.errors
|
||||||
|
-# Ignore the :taken error if the path can be claimed
|
||||||
|
- if errors.details[:path]&.pluck(:error)&.include?(:taken) && @procedure.path_available?(administrateur, procedure.path)
|
||||||
|
- errors.delete(:path)
|
||||||
|
|
||||||
|
- options = { class: "button primary", id: 'publish' }
|
||||||
|
- if errors.details[:path].present?
|
||||||
|
- options[:disabled] = :disabled
|
||||||
|
.flex.justify-end
|
||||||
|
= submit_tag procedure_publish_text(@procedure, :submit), options
|
|
@ -0,0 +1,90 @@
|
||||||
|
|
||||||
|
= render partial: 'new_administrateur/breadcrumbs',
|
||||||
|
locals: { steps: [link_to('Démarches', admin_procedures_path),
|
||||||
|
link_to(@procedure.libelle, admin_procedure_path(@procedure)),
|
||||||
|
'Publication'] }
|
||||||
|
.container
|
||||||
|
.lien-demarche
|
||||||
|
%h1
|
||||||
|
- if @procedure.brouillon?
|
||||||
|
Test et publication
|
||||||
|
- else
|
||||||
|
Publication
|
||||||
|
%div{ style: 'margin-top: 30px;' }
|
||||||
|
- if @procedure.close? || @procedure.depubliee?
|
||||||
|
%p.mb-4 Cette démarche est <strong>close</strong> et n’est donc plus accessible par le public. Vous pouvez la réactiver :
|
||||||
|
= render partial: 'publication_form', locals: { procedure: @procedure, administrateur: @current_administrateur }
|
||||||
|
- elsif @procedure.publiee?
|
||||||
|
%p Cette démarche est <strong>publiée</strong>, certains éléments ne peuvent plus être modifiés.
|
||||||
|
Pour y accéder vous pouvez utiliser le lien :
|
||||||
|
= link_to @procedure_lien, sanitize_url(@procedure_lien), target: :blank, rel: :noopener, class: "mb-4"
|
||||||
|
|
||||||
|
%p.mb-4 Attention, diffusez toujours le <strong>lien complet</strong> affiché ci-dessus, et non pas un lien générique vers #{APPLICATION_NAME}. Ne dites pas non plus aux usagers de se rendre sur le site générique #{APPLICATION_NAME}, donnez-leur toujours le lien complet.
|
||||||
|
|
||||||
|
= render partial: 'procedure_transfert'
|
||||||
|
- elsif @procedure.brouillon?
|
||||||
|
- if @procedure.missing_steps.empty?
|
||||||
|
%p
|
||||||
|
Cette démarche est actuellement <strong>en test</strong>,
|
||||||
|
pour y accéder vous pouvez utiliser le lien :
|
||||||
|
= link_to @procedure_lien, sanitize_url(@procedure_lien), target: :blank, rel: :noopener
|
||||||
|
%p.mb-4
|
||||||
|
Toute personne ayant la connaissance de ce lien pourra ainsi remplir des dossiers de test sur votre démarche.
|
||||||
|
|
||||||
|
.card.mb-4
|
||||||
|
%h2.card-title Ce que vous pouvez faire lorsque vous êtes en test
|
||||||
|
%p
|
||||||
|
Profitez de la phase de test pour tester la saisie de dossiers, ainsi que toutes les fonctionnalités associées (instruction, emails automatiques, attestations, etc.).
|
||||||
|
%p
|
||||||
|
Vous pouvez effectuer toutes les modifications que vous souhaitez sur votre démarche pendant cette phase de test.
|
||||||
|
%p.mb-4.bold
|
||||||
|
Les dossiers qui seront remplis pendant la phase de test seront automatiquement supprimés lors de la modification ou la publication de votre démarche.
|
||||||
|
%p.center
|
||||||
|
%iframe{ :src =>"https://player.vimeo.com/video/334463514?color=0069CC",:width =>"640",:height =>"360",:frameborder => "0" }
|
||||||
|
|
||||||
|
|
||||||
|
.card
|
||||||
|
%h2.card-title Prêt à publier ?
|
||||||
|
%p
|
||||||
|
À ce moment du processus de création, vous devez informer votre Délégué à la Protection des Données personnelles (DPD).
|
||||||
|
%p
|
||||||
|
(
|
||||||
|
%a{ href:'https://www.cnil.fr/fr/protection-des-donnees-les-bons-reflexes', target:'_blank' }
|
||||||
|
https://www.cnil.fr/fr/protection-des-donnees-les-bons-reflexes
|
||||||
|
)
|
||||||
|
%p
|
||||||
|
Si votre démarche propose de collecter des données personnelles, vous devez informer votre DPD. Chaque organisme en a un.
|
||||||
|
%p
|
||||||
|
Ce dernier pourra vous aider dans la finalisation de votre démarche, et vous inviter à vous interroger sur les données collectées, et sur la pertinence de ces dernières.
|
||||||
|
N'oubliez pas : toutes les démarches qui contiennent des données personnelles doivent être consignées dans un registre des traitements :
|
||||||
|
%a{ href:'https://www.cnil.fr/fr/RGDP-le-registre-des-activites-de-traitement', target:'_blank' }
|
||||||
|
https://www.cnil.fr/fr/RGDP-le-registre-des-activites-de-traitement
|
||||||
|
%p.mb-4
|
||||||
|
Comment faire :
|
||||||
|
vous pouvez soit lui communiquer par email le lien vers la démarche en test, ou bien le nommer « administrateur ». Dans tous les cas, ne publiez votre démarche qu’après avoir eu son avis.
|
||||||
|
|
||||||
|
= render partial: 'publication_form', locals: { procedure: @procedure, administrateur: @current_administrateur }
|
||||||
|
|
||||||
|
- else
|
||||||
|
.alert.alert-info
|
||||||
|
Pour pouvoir tester cette démarche, vous devez d’abord lui affecter
|
||||||
|
- if @procedure.missing_instructeurs?
|
||||||
|
= link_to("des instructeurs", admin_procedure_groupe_instructeur_path(@procedure, @procedure.defaut_groupe_instructeur))
|
||||||
|
- if @procedure.missing_instructeurs? && @procedure.service.nil?
|
||||||
|
et
|
||||||
|
- if @procedure.service.nil?
|
||||||
|
= link_to("un service", admin_services_path(procedure_id: @procedure))
|
||||||
|
\.
|
||||||
|
- else
|
||||||
|
- if @procedure.missing_steps.include?(:service)
|
||||||
|
%p.alert.alert-danger
|
||||||
|
Vous devez renseigner les coordonnées de votre Service administratif avant de pouvoir publier votre démarche.
|
||||||
|
= link_to 'Cliquez ici.', (@current_administrateur.services.present? ? url_for(admin_services_path(procedure_id: @procedure.id)) : url_for(new_admin_service_path(procedure_id: @procedure.id)))
|
||||||
|
|
||||||
|
- if @procedure.missing_steps.include?(:instructeurs)
|
||||||
|
%p.alert.alert-danger
|
||||||
|
Vous devez affecter des instructeurs avant de pouvoir publier votre démarche.
|
||||||
|
= link_to 'Cliquez ici.', admin_procedure_groupe_instructeur_path(@procedure, @procedure.defaut_groupe_instructeur)
|
||||||
|
|
||||||
|
%p.alert.alert-info
|
||||||
|
Cette démarche n’a pas encore de lien, et n’est pas accessible par le public.
|
|
@ -1,9 +1,9 @@
|
||||||
= render partial: 'new_administrateur/breadcrumbs',
|
= render partial: 'new_administrateur/breadcrumbs',
|
||||||
locals: { steps: [link_to('Démarches', admin_procedures_path),
|
locals: { steps: [link_to('Démarches', admin_procedures_path),
|
||||||
"#{@procedure.libelle} (crée le #{@procedure.created_at.strftime('%d/%m/%Y')})", "#{@procedure.locked? ? "Publiée" : "Brouillon" }"] }
|
"#{@procedure.libelle} (crée le #{@procedure.created_at.strftime('%d/%m/%Y')})", "#{@procedure.close? ? "Close" : @procedure.locked? ? "Publiée" : "Brouillon"}"] }
|
||||||
|
|
||||||
.container.procedure-admin-container
|
.container.procedure-admin-container
|
||||||
= link_to apercu_admin_procedure_path(@procedure), class: 'button' do
|
= link_to apercu_admin_procedure_path(@procedure), class: 'button', id: "preview-procedure" do
|
||||||
%span.icon.preview
|
%span.icon.preview
|
||||||
Prévisualiser
|
Prévisualiser
|
||||||
|
|
||||||
|
@ -17,11 +17,14 @@
|
||||||
%span.icon.reply
|
%span.icon.reply
|
||||||
Envoyer une copie
|
Envoyer une copie
|
||||||
|
|
||||||
- if !@procedure.publiee?
|
- if !@procedure.publiee? && !@procedure.close? && !@procedure.depubliee?
|
||||||
= link_to 'Publier', admin_procedure_publication_path(@procedure), class: 'button primary', id: 'publish-procedure-link', data: { disable_with: "Publication..." }
|
= link_to 'Publier', admin_procedure_publication_path(@procedure), class: 'button primary', id: 'publish-procedure-link', data: { disable_with: "Publication..." }
|
||||||
|
|
||||||
|
- if @procedure.close? || @procedure.depubliee?
|
||||||
|
= link_to 'Réactiver', admin_procedure_publication_path(@procedure), class: 'button primary', id: 'publish-procedure-link', data: { disable_with: "Publication..." }
|
||||||
|
|
||||||
- if @procedure.locked? && !@procedure.close?
|
- if @procedure.locked? && !@procedure.close?
|
||||||
= link_to admin_procedure_archive_path(procedure_id: @procedure.id), method: :put, class: 'button', data: { confirm: "Voulez-vous vraiment clore la démarche ? \nLes dossiers en cours pourront être instruits, mais aucun nouveau dossier ne pourra plus être déposé.", disable_with: "Archivage..."} do
|
= link_to admin_procedure_archive_path(procedure_id: @procedure.id), method: :put, class: 'button', id: "close-procedure-link", data: { confirm: "Voulez-vous vraiment clore la démarche ? \nLes dossiers en cours pourront être instruits, mais aucun nouveau dossier ne pourra plus être déposé.", disable_with: "Archivage..."} do
|
||||||
%span.icon.archive
|
%span.icon.archive
|
||||||
Clore
|
Clore
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
- if champ.geometry?
|
- if champ.geometry?
|
||||||
= react_component("MapReader", { featureCollection: champ.to_feature_collection, ign: feature_enabled_for?(:carte_ign, champ.procedure) } )
|
= react_component("MapReader", { featureCollection: champ.to_feature_collection, options: champ.render_options } )
|
||||||
.geo-areas
|
.geo-areas
|
||||||
= render partial: 'shared/champs/carte/geo_areas', locals: { champ: champ, editing: false }
|
= render partial: 'shared/champs/carte/geo_areas', locals: { champ: champ, editing: false }
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
- preview = !champ.persisted?
|
- preview = !champ.persisted?
|
||||||
= react_component("MapEditor", { featureCollection: champ.to_feature_collection, url: champs_carte_features_path(preview ? 'preview' : champ), preview: preview, hasCadastres: !!champ.cadastres?, ign: feature_enabled_for?(:carte_ign, champ.procedure) }, class: "carte-#{champ.id}")
|
- url = champs_carte_features_path(preview ? 'preview' : champ)
|
||||||
|
= react_component("MapEditor", { featureCollection: champ.to_feature_collection, url: url, preview: preview, options: champ.render_options }, class: "carte-#{champ.id}")
|
||||||
|
|
||||||
.geo-areas
|
.geo-areas
|
||||||
= render partial: 'shared/champs/carte/geo_areas', locals: { champ: champ, editing: true }
|
= render partial: 'shared/champs/carte/geo_areas', locals: { champ: champ, editing: true }
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
.dropdown.help-dropdown
|
.dropdown.help-dropdown
|
||||||
%button.button.primary.dropdown-button Aide
|
%button.button.primary.dropdown-button{ 'aria-expanded' => 'false', 'aria-controls' => 'help-menu' } Aide
|
||||||
.dropdown-content.fade-in-down
|
#help-menu.dropdown-content.fade-in-down
|
||||||
%ul.dropdown-items
|
%ul.dropdown-items
|
||||||
- title = dossier.brouillon? ? "Besoin d’aide pour remplir votre dossier ?" : "Une question sur votre dossier ?"
|
- title = dossier.brouillon? ? "Besoin d’aide pour remplir votre dossier ?" : "Une question sur votre dossier ?"
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
.dropdown.help-dropdown
|
.dropdown.help-dropdown
|
||||||
%button.button.primary.dropdown-button Aide
|
%button.button.primary.dropdown-button{ 'aria-expanded' => 'false', 'aria-controls' => 'help-menu' } Aide
|
||||||
.dropdown-content.fade-in-down
|
#help-menu.dropdown-content.fade-in-down
|
||||||
%ul.dropdown-items
|
%ul.dropdown-items
|
||||||
= render partial: 'shared/help/dropdown_items/faq_item'
|
= render partial: 'shared/help/dropdown_items/faq_item'
|
||||||
= render partial: 'shared/help/dropdown_items/email_item'
|
= render partial: 'shared/help/dropdown_items/email_item'
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
.dropdown.help-dropdown
|
.dropdown.help-dropdown
|
||||||
%button.button.primary.dropdown-button Aide
|
%button.button.primary.dropdown-button{ 'aria-expanded' => 'false', 'aria-controls' => 'help-menu' } Aide
|
||||||
.dropdown-content.fade-in-down
|
#help-menu.dropdown-content.fade-in-down
|
||||||
%ul.dropdown-items
|
%ul.dropdown-items
|
||||||
- if procedure.service.present?
|
- if procedure.service.present?
|
||||||
= render partial: 'shared/help/dropdown_items/service_item',
|
= render partial: 'shared/help/dropdown_items/service_item',
|
||||||
|
|
|
@ -5,9 +5,9 @@
|
||||||
|
|
||||||
- if has_actions
|
- if has_actions
|
||||||
.dropdown.user-dossier-actions
|
.dropdown.user-dossier-actions
|
||||||
%button.button.dropdown-button
|
%button.button.dropdown-button{ 'aria-expanded' => 'false', 'aria-controls' => 'actions-menu' }
|
||||||
Actions
|
Actions
|
||||||
.dropdown-content.fade-in-down
|
#actions-menu.dropdown-content.fade-in-down
|
||||||
%ul.dropdown-items
|
%ul.dropdown-items
|
||||||
- if !dossier.read_only?
|
- if !dossier.read_only?
|
||||||
- if dossier.brouillon?
|
- if dossier.brouillon?
|
||||||
|
|
|
@ -16,9 +16,9 @@
|
||||||
- if dossier.can_be_updated_by_user? && !current_page?(modifier_dossier_path(dossier))
|
- if dossier.can_be_updated_by_user? && !current_page?(modifier_dossier_path(dossier))
|
||||||
= link_to "Modifier mon dossier", modifier_dossier_path(dossier), class: 'button accepted edit-form', 'title'=> "Vous pouvez modifier votre dossier tant qu'il n'est passé en instruction"
|
= link_to "Modifier mon dossier", modifier_dossier_path(dossier), class: 'button accepted edit-form', 'title'=> "Vous pouvez modifier votre dossier tant qu'il n'est passé en instruction"
|
||||||
%span.dropdown.print-menu-opener
|
%span.dropdown.print-menu-opener
|
||||||
%button.button.dropdown-button.icon-only{ title: 'imprimer', 'aria-label': 'imprimer' }
|
%button.button.dropdown-button.icon-only{ title: 'imprimer', 'aria-label': 'imprimer', 'aria-expanded' => 'false', 'aria-controls' => 'print-menu' }
|
||||||
%span.icon.printer
|
%span.icon.printer
|
||||||
%ul.print-menu.dropdown-content
|
%ul#print-menu.print-menu.dropdown-content
|
||||||
%li
|
%li
|
||||||
= link_to "Tout le dossier", dossier_path(dossier, format: :pdf), target: "_blank", rel: "noopener", class: "menu-item menu-link"
|
= link_to "Tout le dossier", dossier_path(dossier, format: :pdf), target: "_blank", rel: "noopener", class: "menu-item menu-link"
|
||||||
|
|
||||||
|
|
|
@ -176,7 +176,6 @@ Rails.application.routes.draw do
|
||||||
patch 'activate' => '/administrateurs/activate#create'
|
patch 'activate' => '/administrateurs/activate#create'
|
||||||
get 'procedures/archived' => 'procedures#archived'
|
get 'procedures/archived' => 'procedures#archived'
|
||||||
get 'procedures/draft' => 'procedures#draft'
|
get 'procedures/draft' => 'procedures#draft'
|
||||||
get 'procedures/:id/publication' => 'procedures#show', as: :procedure_publication
|
|
||||||
|
|
||||||
resources :procedures, only: [:destroy] do
|
resources :procedures, only: [:destroy] do
|
||||||
collection do
|
collection do
|
||||||
|
@ -191,8 +190,6 @@ Rails.application.routes.draw do
|
||||||
|
|
||||||
put 'archive' => 'procedures#archive', as: :archive
|
put 'archive' => 'procedures#archive', as: :archive
|
||||||
get 'publish_validate' => 'procedures#publish_validate', as: :publish_validate
|
get 'publish_validate' => 'procedures#publish_validate', as: :publish_validate
|
||||||
put 'publish' => 'procedures#publish', as: :publish
|
|
||||||
post 'transfer' => 'procedures#transfer', as: :transfer
|
|
||||||
put 'clone' => 'procedures#clone', as: :clone
|
put 'clone' => 'procedures#clone', as: :clone
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -371,6 +368,10 @@ Rails.application.routes.draw do
|
||||||
patch 'update_jeton'
|
patch 'update_jeton'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
get 'publication' => 'procedures#publication', as: :publication
|
||||||
|
put 'publish' => 'procedures#publish', as: :publish
|
||||||
|
post 'transfer' => 'procedures#transfer', as: :transfer
|
||||||
|
|
||||||
resources :mail_templates, only: [:edit, :update]
|
resources :mail_templates, only: [:edit, :update]
|
||||||
|
|
||||||
resources :groupe_instructeurs, only: [:index, :show, :create, :update, :destroy] do
|
resources :groupe_instructeurs, only: [:index, :show, :create, :update, :destroy] do
|
||||||
|
|
|
@ -35,48 +35,12 @@ describe Admin::ProceduresController, type: :controller do
|
||||||
sign_in(admin.user)
|
sign_in(admin.user)
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'GET #index' do
|
|
||||||
subject { get :index }
|
|
||||||
|
|
||||||
it { expect(response.status).to eq(200) }
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'GET #archived' do
|
|
||||||
subject { get :archived }
|
|
||||||
|
|
||||||
it { expect(response.status).to eq(200) }
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'GET #archived with sorting and pagination' do
|
|
||||||
subject {
|
|
||||||
get :archived, params: {
|
|
||||||
'procedures_smart_listing[page]': 1,
|
|
||||||
'procedures_smart_listing[per_page]': 10,
|
|
||||||
'procedures_smart_listing[sort][libelle]': 'asc'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
it { expect(subject.status).to eq(200) }
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'GET #published' do
|
describe 'GET #published' do
|
||||||
subject { get :published }
|
subject { get :published }
|
||||||
|
|
||||||
it { expect(response.status).to eq(200) }
|
it { expect(response.status).to eq(200) }
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'GET #draft with sorting and pagination' do
|
|
||||||
subject {
|
|
||||||
get :draft, params: {
|
|
||||||
'procedures_smart_listing[page]': 1,
|
|
||||||
'procedures_smart_listing[per_page]': 10,
|
|
||||||
'procedures_smart_listing[sort][published_at]': 'asc'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
it { expect(subject.status).to eq(200) }
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'DELETE #destroy' do
|
describe 'DELETE #destroy' do
|
||||||
let(:procedure_draft) { create(:procedure, administrateurs: [admin]) }
|
let(:procedure_draft) { create(:procedure, administrateurs: [admin]) }
|
||||||
let(:procedure_published) { create(:procedure, :published, administrateurs: [admin]) }
|
let(:procedure_published) { create(:procedure, :published, administrateurs: [admin]) }
|
||||||
|
@ -142,118 +106,6 @@ describe Admin::ProceduresController, type: :controller do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'PUT #publish' do
|
|
||||||
let(:procedure) { create(:procedure, administrateur: admin, lien_site_web: lien_site_web) }
|
|
||||||
let(:procedure2) { create(:procedure, :published, administrateur: admin, lien_site_web: lien_site_web) }
|
|
||||||
let(:procedure3) { create(:procedure, :published, lien_site_web: lien_site_web) }
|
|
||||||
let(:lien_site_web) { 'http://some.administration/' }
|
|
||||||
|
|
||||||
context 'when admin is the owner of the procedure' do
|
|
||||||
before do
|
|
||||||
put :publish, params: { procedure_id: procedure.id, path: path, lien_site_web: lien_site_web }, format: 'js'
|
|
||||||
procedure.reload
|
|
||||||
procedure2.reload
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'procedure path does not exist' do
|
|
||||||
let(:path) { 'new_path' }
|
|
||||||
let(:lien_site_web) { 'http://mon-site.gouv.fr' }
|
|
||||||
|
|
||||||
it 'publish the given procedure' do
|
|
||||||
expect(procedure.publiee?).to be_truthy
|
|
||||||
expect(procedure.path).to eq(path)
|
|
||||||
expect(procedure.lien_site_web).to eq(lien_site_web)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'redirects to the procedures page' do
|
|
||||||
expect(response.status).to eq 200
|
|
||||||
expect(response.body).to include(admin_procedures_path)
|
|
||||||
expect(flash[:notice]).to have_content 'Démarche publiée'
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'procedure path exists and is owned by current administrator' do
|
|
||||||
let(:path) { procedure2.path }
|
|
||||||
let(:lien_site_web) { 'http://mon-site.gouv.fr' }
|
|
||||||
|
|
||||||
it 'publish the given procedure' do
|
|
||||||
expect(procedure.publiee?).to be_truthy
|
|
||||||
expect(procedure.path).to eq(path)
|
|
||||||
expect(procedure.lien_site_web).to eq(lien_site_web)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'depubliee previous procedure' do
|
|
||||||
expect(procedure2.depubliee?).to be_truthy
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'redirects to the procedures page' do
|
|
||||||
expect(response.status).to eq 200
|
|
||||||
expect(response.body).to include(admin_procedures_path)
|
|
||||||
expect(flash[:notice]).to have_content 'Démarche publiée'
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'procedure path exists and is not owned by current administrator' do
|
|
||||||
let(:path) { procedure3.path }
|
|
||||||
let(:lien_site_web) { 'http://mon-site.gouv.fr' }
|
|
||||||
|
|
||||||
it 'does not publish the given procedure' do
|
|
||||||
expect(procedure.publiee?).to be_falsey
|
|
||||||
expect(procedure.path).not_to match(path)
|
|
||||||
expect(procedure.lien_site_web).to match(lien_site_web)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'previous procedure remains published' do
|
|
||||||
expect(procedure2.publiee?).to be_truthy
|
|
||||||
expect(procedure2.close?).to be_falsey
|
|
||||||
expect(procedure2.path).to match(/fake_path/)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'procedure path is invalid' do
|
|
||||||
let(:path) { 'Invalid Procedure Path' }
|
|
||||||
let(:lien_site_web) { 'http://mon-site.gouv.fr' }
|
|
||||||
|
|
||||||
it 'does not publish the given procedure' do
|
|
||||||
expect(procedure.publiee?).to be_falsey
|
|
||||||
expect(procedure.path).not_to match(path)
|
|
||||||
expect(procedure.lien_site_web).to match(lien_site_web)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'when admin is not the owner of the procedure' do
|
|
||||||
let(:admin_2) { create(:administrateur) }
|
|
||||||
|
|
||||||
before do
|
|
||||||
sign_out(admin.user)
|
|
||||||
sign_in(admin_2.user)
|
|
||||||
|
|
||||||
put :publish, params: { procedure_id: procedure.id, path: 'fake_path' }, format: 'js'
|
|
||||||
procedure.reload
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'fails' do
|
|
||||||
expect(response).to have_http_status(404)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'when the admin does not provide a lien_site_web' do
|
|
||||||
before do
|
|
||||||
put :publish, params: { procedure_id: procedure.id, path: path, lien_site_web: lien_site_web }, format: 'js'
|
|
||||||
procedure.reload
|
|
||||||
end
|
|
||||||
context 'procedure path is valid but lien_site_web is missing' do
|
|
||||||
let(:path) { 'new_path2' }
|
|
||||||
let(:lien_site_web) { nil }
|
|
||||||
|
|
||||||
it 'does not publish the given procedure' do
|
|
||||||
expect(procedure.publiee?).to be_falsey
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'PUT #archive' do
|
describe 'PUT #archive' do
|
||||||
let(:procedure) { create(:procedure, :published, administrateur: admin, lien_site_web: lien_site_web) }
|
let(:procedure) { create(:procedure, :published, administrateur: admin, lien_site_web: lien_site_web) }
|
||||||
|
|
||||||
|
@ -268,21 +120,6 @@ describe Admin::ProceduresController, type: :controller do
|
||||||
it { expect(response).to redirect_to :admin_procedures }
|
it { expect(response).to redirect_to :admin_procedures }
|
||||||
it { expect(flash[:notice]).to have_content 'Démarche close' }
|
it { expect(flash[:notice]).to have_content 'Démarche close' }
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'when owner want to re-enable procedure' do
|
|
||||||
before do
|
|
||||||
put :publish, params: { procedure_id: procedure.id, path: 'fake_path', lien_site_web: lien_site_web }
|
|
||||||
procedure.reload
|
|
||||||
end
|
|
||||||
|
|
||||||
it { expect(procedure.publiee?).to be_truthy }
|
|
||||||
|
|
||||||
it 'redirects to the procedures page' do
|
|
||||||
expect(response.status).to eq 200
|
|
||||||
expect(response.body).to include(admin_procedures_path)
|
|
||||||
expect(flash[:notice]).to have_content 'Démarche publiée'
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'when admin is not the owner of the procedure' do
|
context 'when admin is not the owner of the procedure' do
|
||||||
|
@ -391,53 +228,6 @@ describe Admin::ProceduresController, type: :controller do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'POST #transfer' do
|
|
||||||
let!(:procedure) { create :procedure, :with_service, administrateur: admin }
|
|
||||||
|
|
||||||
subject do
|
|
||||||
post :transfer, params: { email_admin: email_admin, procedure_id: procedure.id }, format: 'js'
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'when admin is unknow' do
|
|
||||||
let(:email_admin) { 'plop' }
|
|
||||||
|
|
||||||
it { expect(subject.status).to eq 404 }
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'when admin is known' do
|
|
||||||
let!(:new_admin) { create :administrateur, email: 'new_admin@admin.com' }
|
|
||||||
|
|
||||||
context "and its email address is correct" do
|
|
||||||
let(:email_admin) { 'new_admin@admin.com' }
|
|
||||||
|
|
||||||
it { expect(subject.status).to eq 200 }
|
|
||||||
it { expect { subject }.to change(new_admin.procedures, :count).by(1) }
|
|
||||||
|
|
||||||
it "should create a new service" do
|
|
||||||
subject
|
|
||||||
expect(new_admin.procedures.last.service_id).not_to eq(procedure.service_id)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'when admin is know but its email was not downcased' do
|
|
||||||
let(:email_admin) { "NEW_admin@adMIN.com" }
|
|
||||||
|
|
||||||
it { expect(subject.status).to eq 200 }
|
|
||||||
it { expect { subject }.to change(Procedure, :count).by(1) }
|
|
||||||
end
|
|
||||||
|
|
||||||
describe "correctly assigns the new admin" do
|
|
||||||
let(:email_admin) { 'new_admin@admin.com' }
|
|
||||||
|
|
||||||
before do
|
|
||||||
subject
|
|
||||||
end
|
|
||||||
|
|
||||||
it { expect(Procedure.last.administrateurs).to eq [new_admin] }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe "DELETE #delete_deliberation" do
|
describe "DELETE #delete_deliberation" do
|
||||||
context "with a demarche the admin owns" do
|
context "with a demarche the admin owns" do
|
||||||
let(:procedure) { create(:procedure, :with_deliberation, administrateur: admin) }
|
let(:procedure) { create(:procedure, :with_deliberation, administrateur: admin) }
|
||||||
|
|
|
@ -340,4 +340,152 @@ describe NewAdministrateur::ProceduresController, type: :controller do
|
||||||
expect(procedure.reload.api_entreprise_token).to eq(valid_token)
|
expect(procedure.reload.api_entreprise_token).to eq(valid_token)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe 'PUT #publish' do
|
||||||
|
let(:procedure) { create(:procedure, administrateur: admin, lien_site_web: lien_site_web) }
|
||||||
|
let(:procedure2) { create(:procedure, :published, administrateur: admin, lien_site_web: lien_site_web) }
|
||||||
|
let(:procedure3) { create(:procedure, :published, lien_site_web: lien_site_web) }
|
||||||
|
let(:lien_site_web) { 'http://some.administration/' }
|
||||||
|
|
||||||
|
context 'when admin is the owner of the procedure' do
|
||||||
|
context 'procedure path does not exist' do
|
||||||
|
let(:path) { 'new_path' }
|
||||||
|
let(:lien_site_web) { 'http://mon-site.gouv.fr' }
|
||||||
|
|
||||||
|
before do
|
||||||
|
put :publish, params: { procedure_id: procedure.id, path: path, lien_site_web: lien_site_web }
|
||||||
|
procedure.reload
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'publish the given procedure' do
|
||||||
|
expect(procedure.publiee?).to be_truthy
|
||||||
|
expect(procedure.path).to eq(path)
|
||||||
|
expect(procedure.lien_site_web).to eq(lien_site_web)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'redirects to the procedure page' do
|
||||||
|
expect(response.status).to eq 302
|
||||||
|
expect(response.body).to include(admin_procedure_path(procedure.id))
|
||||||
|
expect(flash[:notice]).to have_content 'Démarche publiée'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'procedure path exists and is owned by current administrator' do
|
||||||
|
before do
|
||||||
|
put :publish, params: { procedure_id: procedure.id, path: path, lien_site_web: lien_site_web }
|
||||||
|
procedure.reload
|
||||||
|
procedure2.reload
|
||||||
|
end
|
||||||
|
|
||||||
|
let(:path) { procedure2.path }
|
||||||
|
let(:lien_site_web) { 'http://mon-site.gouv.fr' }
|
||||||
|
|
||||||
|
it 'publish the given procedure' do
|
||||||
|
expect(procedure.publiee?).to be_truthy
|
||||||
|
expect(procedure.path).to eq(path)
|
||||||
|
expect(procedure.lien_site_web).to eq(lien_site_web)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'depubliee previous procedure' do
|
||||||
|
expect(procedure2.depubliee?).to be_truthy
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'redirects to the procedures page' do
|
||||||
|
expect(response.status).to eq 302
|
||||||
|
expect(response.body).to include(admin_procedure_path(procedure.id))
|
||||||
|
expect(flash[:notice]).to have_content 'Démarche publiée'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'procedure path exists and is not owned by current administrator' do
|
||||||
|
let(:path) { procedure3.path }
|
||||||
|
let(:lien_site_web) { 'http://mon-site.gouv.fr' }
|
||||||
|
it { expect { put :publish, params: { procedure_id: procedure.id, path: path, lien_site_web: lien_site_web } }.to raise_error(ActiveRecord::RecordInvalid) }
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'procedure path is invalid' do
|
||||||
|
let(:lien_site_web) { 'http://mon-site.gouv.fr' }
|
||||||
|
let(:path) { 'Invalid Procedure Path' }
|
||||||
|
it { expect { put :publish, params: { procedure_id: procedure.id, path: path, lien_site_web: lien_site_web } }.to raise_error(ActiveRecord::RecordInvalid) }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when admin is not the owner of the procedure' do
|
||||||
|
let(:admin_2) { create(:administrateur) }
|
||||||
|
before do
|
||||||
|
sign_out(admin.user)
|
||||||
|
sign_in(admin_2.user)
|
||||||
|
|
||||||
|
put :publish, params: { procedure_id: procedure.id, path: 'fake_path' }
|
||||||
|
procedure.reload
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'fails' do
|
||||||
|
expect(response).to have_http_status(404)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when the admin does not provide a lien_site_web' do
|
||||||
|
context 'procedure path is valid but lien_site_web is missing' do
|
||||||
|
let(:path) { 'new_path2' }
|
||||||
|
let(:lien_site_web) { nil }
|
||||||
|
it { expect { put :publish, params: { procedure_id: procedure.id, path: path, lien_site_web: lien_site_web } }.to raise_error(ActiveRecord::RecordInvalid) }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'POST #transfer' do
|
||||||
|
let!(:procedure) { create :procedure, :with_service, administrateur: admin }
|
||||||
|
|
||||||
|
before do
|
||||||
|
post :transfer, params: { email_admin: email_admin, procedure_id: procedure.id }
|
||||||
|
procedure.reload
|
||||||
|
end
|
||||||
|
|
||||||
|
subject do
|
||||||
|
post :transfer, params: { email_admin: email_admin, procedure_id: procedure.id }
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when admin is unknow' do
|
||||||
|
let(:email_admin) { 'plop' }
|
||||||
|
|
||||||
|
it { expect(subject.status).to eq 302 }
|
||||||
|
it { expect(response.body).to include(admin_procedure_publication_path(procedure.id)) }
|
||||||
|
it { expect(flash[:alert]).to be_present }
|
||||||
|
it { expect(flash[:alert]).to eq("Envoi vers #{email_admin} impossible : cet administrateur n'existe pas") }
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when admin is known' do
|
||||||
|
let!(:new_admin) { create :administrateur, email: 'new_admin@admin.com' }
|
||||||
|
|
||||||
|
context "and its email address is correct" do
|
||||||
|
let(:email_admin) { 'new_admin@admin.com' }
|
||||||
|
|
||||||
|
it { expect(subject.status).to eq 302 }
|
||||||
|
it { expect { subject }.to change(new_admin.procedures, :count).by(1) }
|
||||||
|
|
||||||
|
it "should create a new service" do
|
||||||
|
subject
|
||||||
|
expect(new_admin.procedures.last.service_id).not_to eq(procedure.service_id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when admin is know but its email was not downcased' do
|
||||||
|
let(:email_admin) { "NEW_admin@adMIN.com" }
|
||||||
|
|
||||||
|
it { expect(subject.status).to eq 302 }
|
||||||
|
it { expect { subject }.to change(Procedure, :count).by(1) }
|
||||||
|
end
|
||||||
|
|
||||||
|
describe "correctly assigns the new admin" do
|
||||||
|
let(:email_admin) { 'new_admin@admin.com' }
|
||||||
|
|
||||||
|
before do
|
||||||
|
subject
|
||||||
|
end
|
||||||
|
|
||||||
|
it { expect(Procedure.last.administrateurs).to eq [new_admin] }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -20,26 +20,21 @@ feature 'As an administrateur I wanna clone a procedure', js: true do
|
||||||
expect(page.find_by_id('procedures')['data-item-count']).to eq('1')
|
expect(page.find_by_id('procedures')['data-item-count']).to eq('1')
|
||||||
page.all('.procedures-actions-btn').first.click
|
page.all('.procedures-actions-btn').first.click
|
||||||
page.all('.clone-btn').first.click
|
page.all('.clone-btn').first.click
|
||||||
visit admin_procedures_draft_path
|
visit admin_procedures_path(statut: "brouillons")
|
||||||
expect(page.find_by_id('procedures')['data-item-count']).to eq('1')
|
expect(page.find_by_id('procedures')['data-item-count']).to eq('1')
|
||||||
click_on Procedure.last.libelle
|
click_on Procedure.last.libelle
|
||||||
expect(page).to have_current_path(admin_procedure_path(Procedure.last))
|
expect(page).to have_current_path(admin_procedure_path(Procedure.last))
|
||||||
|
|
||||||
find('#publish-procedure-link').click
|
find('#publish-procedure-link').click
|
||||||
find('#publish-procedure').click
|
expect(find_field('procedure_path').value).to eq 'libelle-de-la-procedure'
|
||||||
|
fill_in 'lien_site_web', with: 'http://some.website'
|
||||||
within '#publish-modal' do
|
click_on 'publish'
|
||||||
expect(find_field('procedure_path').value).to eq 'libelle-de-la-procedure'
|
|
||||||
expect(page).to have_text('ancienne sera dépubliée')
|
|
||||||
fill_in 'lien_site_web', with: 'http://some.website'
|
|
||||||
click_on 'publish'
|
|
||||||
end
|
|
||||||
|
|
||||||
page.refresh
|
page.refresh
|
||||||
|
|
||||||
visit admin_procedures_archived_path
|
visit admin_procedures_path(statut: "archivees")
|
||||||
expect(page.find_by_id('procedures')['data-item-count']).to eq('1')
|
expect(page.find_by_id('procedures')['data-item-count']).to eq('1')
|
||||||
visit admin_procedures_draft_path
|
visit admin_procedures_path(statut: "brouillons")
|
||||||
expect(page.find_by_id('procedures')['data-item-count']).to eq('0')
|
expect(page.find_by_id('procedures')['data-item-count']).to eq('0')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -77,13 +77,11 @@ feature 'As an administrateur I wanna create a new procedure', js: true do
|
||||||
expect(page).to have_selector('#champ-1-libelle')
|
expect(page).to have_selector('#champ-1-libelle')
|
||||||
|
|
||||||
click_on Procedure.last.libelle
|
click_on Procedure.last.libelle
|
||||||
find('#publish-procedure-link').click
|
|
||||||
|
|
||||||
preview_window = window_opened_by { click_on 'onglet-preview' }
|
find('#preview-procedure').click
|
||||||
within_window(preview_window) do
|
|
||||||
expect(page).to have_current_path(apercu_admin_procedure_path(Procedure.last))
|
expect(page).to have_current_path(apercu_admin_procedure_path(Procedure.last))
|
||||||
expect(page).to have_field('libelle de champ')
|
expect(page).to have_field('libelle de champ')
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
scenario 'After adding champ and file, make publication' do
|
scenario 'After adding champ and file, make publication' do
|
||||||
|
@ -102,17 +100,12 @@ feature 'As an administrateur I wanna create a new procedure', js: true do
|
||||||
# (Capybara runs the app on an arbitrary host/port.)
|
# (Capybara runs the app on an arbitrary host/port.)
|
||||||
expect(page).to have_link(nil, href: /#{commencer_test_path(Procedure.last.path)}/)
|
expect(page).to have_link(nil, href: /#{commencer_test_path(Procedure.last.path)}/)
|
||||||
|
|
||||||
expect(page).to have_selector('#publish-procedure', visible: true)
|
expect(page).to have_selector('#procedure_path', visible: true)
|
||||||
find('#publish-procedure').click
|
expect(find_field('procedure_path').value).to eq 'libelle-de-la-procedure'
|
||||||
|
fill_in 'lien_site_web', with: 'http://some.website'
|
||||||
within '#publish-modal' do
|
click_on 'publish'
|
||||||
expect(find_field('procedure_path').value).to eq 'libelle-de-la-procedure'
|
|
||||||
fill_in 'lien_site_web', with: 'http://some.website'
|
|
||||||
click_on 'publish'
|
|
||||||
end
|
|
||||||
|
|
||||||
expect(page).to have_text('Démarche publiée')
|
expect(page).to have_text('Démarche publiée')
|
||||||
expect(page).to have_selector('.procedure-lien')
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -20,21 +20,15 @@ feature 'Publication de démarches', js: true do
|
||||||
|
|
||||||
context 'lorsqu’une démarche est en test' do
|
context 'lorsqu’une démarche est en test' do
|
||||||
scenario 'un administrateur peut la publier' do
|
scenario 'un administrateur peut la publier' do
|
||||||
visit admin_procedures_draft_path
|
visit admin_procedures_path(statut: "brouillons")
|
||||||
click_on procedure.libelle
|
click_on procedure.libelle
|
||||||
find('#publish-procedure-link').click
|
find('#publish-procedure-link').click
|
||||||
within "#procedure_show" do
|
expect(find_field('procedure_path').value).to eq procedure.path
|
||||||
click_on "Publier"
|
fill_in 'lien_site_web', with: 'http://some.website'
|
||||||
end
|
click_on 'Publier'
|
||||||
|
|
||||||
within '#publish-modal' do
|
|
||||||
expect(find_field('procedure_path').value).to eq procedure.path
|
|
||||||
fill_in 'lien_site_web', with: 'http://some.website'
|
|
||||||
click_on 'publish'
|
|
||||||
end
|
|
||||||
|
|
||||||
expect(page).to have_text('Démarche publiée')
|
expect(page).to have_text('Démarche publiée')
|
||||||
expect(page).to have_selector('.procedure-lien')
|
expect(page).to have_selector('#preview-procedure')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -50,21 +44,16 @@ feature 'Publication de démarches', js: true do
|
||||||
end
|
end
|
||||||
|
|
||||||
scenario 'un administrateur peut la publier' do
|
scenario 'un administrateur peut la publier' do
|
||||||
visit admin_procedures_archived_path
|
visit admin_procedures_path(statut: "archivees")
|
||||||
click_on procedure.libelle
|
click_on procedure.libelle
|
||||||
find('#publish-procedure-link').click
|
find('#publish-procedure-link').click
|
||||||
within "#procedure_show" do
|
|
||||||
click_on "Réactiver"
|
|
||||||
end
|
|
||||||
|
|
||||||
within '#publish-modal' do
|
expect(find_field('procedure_path').value).to eq procedure.path
|
||||||
expect(find_field('procedure_path').value).to eq procedure.path
|
fill_in 'lien_site_web', with: 'http://some.website'
|
||||||
fill_in 'lien_site_web', with: 'http://some.website'
|
click_on 'publish'
|
||||||
click_on 'publish'
|
|
||||||
end
|
|
||||||
|
|
||||||
expect(page).to have_text('Démarche publiée')
|
expect(page).to have_text('Démarche publiée')
|
||||||
expect(page).to have_selector('.procedure-lien')
|
expect(page).to have_selector('#preview-procedure')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -80,21 +69,16 @@ feature 'Publication de démarches', js: true do
|
||||||
end
|
end
|
||||||
|
|
||||||
scenario 'un administrateur peut la publier' do
|
scenario 'un administrateur peut la publier' do
|
||||||
visit admin_procedures_archived_path
|
visit admin_procedures_path(statut: "archivees")
|
||||||
click_on procedure.libelle
|
click_on procedure.libelle
|
||||||
find('#publish-procedure-link').click
|
find('#publish-procedure-link').click
|
||||||
within "#procedure_show" do
|
|
||||||
click_on "Réactiver"
|
|
||||||
end
|
|
||||||
|
|
||||||
within '#publish-modal' do
|
expect(find_field('procedure_path').value).to eq procedure.path
|
||||||
expect(find_field('procedure_path').value).to eq procedure.path
|
fill_in 'lien_site_web', with: 'http://some.website'
|
||||||
fill_in 'lien_site_web', with: 'http://some.website'
|
click_on 'Publier'
|
||||||
click_on 'publish'
|
|
||||||
end
|
|
||||||
|
|
||||||
expect(page).to have_text('Démarche publiée')
|
expect(page).to have_text('Démarche publiée')
|
||||||
expect(page).to have_selector('.procedure-lien')
|
expect(page).to have_selector('#preview-procedure')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -25,7 +25,7 @@ feature 'Administrateurs can edit procedures', js: true do
|
||||||
end
|
end
|
||||||
|
|
||||||
scenario 'the administrator can edit the libelle' do
|
scenario 'the administrator can edit the libelle' do
|
||||||
visit admin_procedures_draft_path
|
visit admin_procedures_path(statut: "brouillons")
|
||||||
click_on procedure.libelle
|
click_on procedure.libelle
|
||||||
find('#presentation').click
|
find('#presentation').click
|
||||||
|
|
||||||
|
|
|
@ -174,11 +174,8 @@ feature 'The routing', js: true do
|
||||||
def publish_procedure(procedure)
|
def publish_procedure(procedure)
|
||||||
click_on procedure.libelle
|
click_on procedure.libelle
|
||||||
find('#publish-procedure-link').click
|
find('#publish-procedure-link').click
|
||||||
find('#publish-procedure').click
|
fill_in 'lien_site_web', with: 'http://some.website'
|
||||||
within '#publish-modal' do
|
click_on 'Publier'
|
||||||
fill_in 'lien_site_web', with: 'http://some.website'
|
|
||||||
click_on 'Publier'
|
|
||||||
end
|
|
||||||
|
|
||||||
expect(page).to have_text('Démarche publiée')
|
expect(page).to have_text('Démarche publiée')
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,77 +0,0 @@
|
||||||
describe 'admin/procedures/show.html.haml', type: :view do
|
|
||||||
let(:closed_at) { nil }
|
|
||||||
let(:procedure) { create(:procedure, :with_service, closed_at: closed_at) }
|
|
||||||
|
|
||||||
before do
|
|
||||||
assign(:procedure, procedure)
|
|
||||||
assign(:procedure_lien, commencer_url(path: procedure.path))
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'procedure is draft' do
|
|
||||||
context 'when procedure does not have a instructeur affected' do
|
|
||||||
before do
|
|
||||||
render
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'publish button is not visible' do
|
|
||||||
it { expect(rendered).not_to have_css('button#publish-procedure') }
|
|
||||||
it { expect(rendered).not_to have_css('button#archive-procedure') }
|
|
||||||
it { expect(rendered).not_to have_css('button#reopen-procedure') }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'when procedure have a instructeur affected' do
|
|
||||||
before do
|
|
||||||
create(:instructeur).assign_to_procedure(procedure)
|
|
||||||
render
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'publish button is visible' do
|
|
||||||
it { expect(rendered).to have_css('button#publish-procedure') }
|
|
||||||
it { expect(rendered).not_to have_css('button#archive-procedure') }
|
|
||||||
it { expect(rendered).not_to have_css('button#reopen-procedure') }
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'procedure path is not customized' do
|
|
||||||
it { expect(rendered).to have_content('Cette démarche est actuellement en test') }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'procedure is published' do
|
|
||||||
before do
|
|
||||||
procedure.publish!
|
|
||||||
procedure.reload
|
|
||||||
render
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'archive button is visible', js: true do
|
|
||||||
it { expect(rendered).not_to have_css('button#publish-procedure') }
|
|
||||||
it { expect(rendered).to have_css('button#archive-procedure') }
|
|
||||||
it { expect(rendered).not_to have_css('button#reopen-procedure') }
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'procedure link is present' do
|
|
||||||
it { expect(rendered).to have_content(commencer_url(path: procedure.path)) }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'procedure is closed' do
|
|
||||||
before do
|
|
||||||
procedure.publish!
|
|
||||||
procedure.close!
|
|
||||||
procedure.reload
|
|
||||||
render
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'Re-enable button is visible' do
|
|
||||||
it { expect(rendered).not_to have_css('button#publish-procedure') }
|
|
||||||
it { expect(rendered).not_to have_css('button#archive-procedure') }
|
|
||||||
it { expect(rendered).to have_css('button#reopen-procedure') }
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'procedure link is present' do
|
|
||||||
it { expect(rendered).to have_content('Cette démarche est close et n’est donc plus accessible par le public.') }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -0,0 +1,55 @@
|
||||||
|
describe 'new_administrateur/procedures/show.html.haml', type: :view do
|
||||||
|
let(:closed_at) { nil }
|
||||||
|
let(:procedure) { create(:procedure, :with_service, closed_at: closed_at) }
|
||||||
|
|
||||||
|
before do
|
||||||
|
assign(:procedure, procedure)
|
||||||
|
assign(:procedure_lien, commencer_url(path: procedure.path))
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'procedure is draft' do
|
||||||
|
context 'when procedure have a instructeur affected' do
|
||||||
|
before do
|
||||||
|
create(:instructeur).assign_to_procedure(procedure)
|
||||||
|
render
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'publish button is visible' do
|
||||||
|
it { expect(rendered).to have_css('#publish-procedure-link') }
|
||||||
|
it { expect(rendered).not_to have_css('#close-procedure-link') }
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'procedure path is not customized' do
|
||||||
|
it { expect(rendered).to have_content('Brouillon') }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'procedure is published' do
|
||||||
|
before do
|
||||||
|
procedure.publish!
|
||||||
|
procedure.reload
|
||||||
|
render
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'archive button is visible', js: true do
|
||||||
|
it { expect(rendered).not_to have_css('#publish-procedure-link') }
|
||||||
|
it { expect(rendered).to have_css('#close-procedure-link') }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'procedure is closed' do
|
||||||
|
before do
|
||||||
|
procedure.publish!
|
||||||
|
procedure.close!
|
||||||
|
procedure.reload
|
||||||
|
render
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'Re-enable button is visible' do
|
||||||
|
it { expect(rendered).not_to have_css('#close-procedure-link') }
|
||||||
|
it { expect(rendered).to have_css('#publish-procedure-link') }
|
||||||
|
it { expect(rendered).to have_content('Réactiver') }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue