diff --git a/Gemfile.lock b/Gemfile.lock index 6ba72d1d77ae45ea6fc70e6265a5139ad24d1256..2083508780a4927fb0d1318c318578e1196eac57 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -88,7 +88,7 @@ GEM autoprefixer-rails (10.4.7.0) execjs (~> 2) aws-eventstream (1.2.0) - aws-partitions (1.595.0) + aws-partitions (1.597.0) aws-sdk-core (3.131.1) aws-eventstream (~> 1, >= 1.0.2) aws-partitions (~> 1, >= 1.525.0) @@ -133,7 +133,7 @@ GEM childprocess (4.1.0) cocoon (1.2.15) concurrent-ruby (1.1.10) - countries (5.0.1) + countries (5.0.2) i18n_data (~> 0.16.0) sixarm_ruby_unaccent (~> 1.1) country_select (7.0.0) @@ -142,9 +142,9 @@ GEM crack (0.4.5) rexml crass (1.0.6) - curation (1.9) + curation (1.10) htmlentities - metainspector + metainspector (~> 5.12) nokogiri delayed_job (4.1.10) activesupport (>= 3.0, < 8.0) @@ -164,6 +164,8 @@ GEM warden (~> 1.2.3) devise-i18n (1.10.2) devise (>= 4.8.0) + domain_name (0.5.20190701) + unf (>= 0.0.5, < 1.0.0) encryptor (3.0.0) enum_help (0.0.19) activesupport (>= 3.0.0) @@ -174,10 +176,39 @@ GEM faceted_search (3.5.13) font-awesome-sass rails (>= 5.2.0, < 7) - faraday (2.3.0) - faraday-net_http (~> 2.0) + faraday (1.10.0) + faraday-em_http (~> 1.0) + faraday-em_synchrony (~> 1.0) + faraday-excon (~> 1.1) + faraday-httpclient (~> 1.0) + faraday-multipart (~> 1.0) + faraday-net_http (~> 1.0) + faraday-net_http_persistent (~> 1.0) + faraday-patron (~> 1.0) + faraday-rack (~> 1.0) + faraday-retry (~> 1.0) ruby2_keywords (>= 0.0.4) - faraday-net_http (2.0.3) + faraday-cookie_jar (0.0.7) + faraday (>= 0.8.0) + http-cookie (~> 1.0.0) + faraday-em_http (1.0.0) + faraday-em_synchrony (1.0.0) + faraday-encoding (0.0.5) + faraday + faraday-excon (1.1.0) + faraday-http-cache (2.4.0) + faraday (>= 0.8) + faraday-httpclient (1.0.1) + faraday-multipart (1.0.4) + multipart-post (~> 2) + faraday-net_http (1.0.1) + faraday-net_http_persistent (1.2.0) + faraday-patron (1.0.0) + faraday-rack (1.0.0) + faraday-retry (1.0.3) + faraday_middleware (1.2.0) + faraday (~> 1.0) + fastimage (2.2.6) ffi (1.15.5) figaro (1.2.0) thor (>= 0.14.0, < 2) @@ -199,10 +230,9 @@ GEM hash_dot (2.5.0) hashdiff (1.0.1) hashie (5.0.0) - hoe (3.23.1) - rake (>= 0.8, < 15.0) - hpricot (0.8.6) htmlentities (4.3.4) + http-cookie (1.0.5) + domain_name (~> 0.5) httparty (0.20.0) mime-types (~> 3.0) multi_xml (>= 0.5.2) @@ -224,7 +254,7 @@ GEM js_cookie_rails (2.2.0) railties (>= 3.1) json (2.6.2) - jwt (2.3.0) + jwt (2.4.1) kamifusen (1.11.2) image_processing rails @@ -250,25 +280,36 @@ GEM mini_mime (>= 0.1.1) marcel (1.0.2) matrix (0.4.2) - metainspector (1.0.2) - hoe (>= 1.3.0) - hpricot (> 0.0.0) + metainspector (5.12.1) + addressable (~> 2.7) + faraday (>= 1.4, < 3.0) + faraday-cookie_jar (~> 0.0) + faraday-encoding (~> 0.0) + faraday-http-cache (~> 2.2) + faraday_middleware (~> 1.0) + fastimage (~> 2.2) + nesty (~> 1.0) + nokogiri (~> 1.11) method_source (1.0.0) mime-types (3.4.1) mime-types-data (~> 3.2015) mime-types-data (3.2022.0105) mini_magick (4.11.0) mini_mime (1.1.2) - mini_portile2 (2.8.0) minitest (5.15.0) msgpack (1.5.2) multi_json (1.15.0) multi_xml (0.6.0) + multipart-post (2.2.0) mustermann (1.1.1) ruby2_keywords (~> 0.0.1) + nesty (1.0.2) nio4r (2.5.8) - nokogiri (1.13.6) - mini_portile2 (~> 2.8.0) + nokogiri (1.13.6-arm64-darwin) + racc (~> 1.4) + nokogiri (1.13.6-x86_64-darwin) + racc (~> 1.4) + nokogiri (1.13.6-x86_64-linux) racc (~> 1.4) oauth2 (1.4.9) faraday (>= 0.17.3, < 3.0) @@ -276,7 +317,7 @@ GEM multi_json (~> 1.3) multi_xml (~> 0.5) rack (>= 1.2, < 3) - octokit (4.23.0) + octokit (4.24.0) faraday (>= 1, < 3) sawyer (~> 0.9) omniauth (2.1.0) @@ -364,7 +405,7 @@ GEM sprockets (> 3.0) sprockets-rails tilt - sawyer (0.9.1) + sawyer (0.9.2) addressable (>= 2.3.5) faraday (>= 0.17.3, < 3) selenium-webdriver (4.2.1) @@ -412,6 +453,9 @@ GEM ethon (>= 0.9.0) tzinfo (2.0.4) concurrent-ruby (~> 1.0) + unf (0.1.4) + unf_ext + unf_ext (0.0.8.2) unicode-display_width (2.1.0) unicode_utils (1.4.0) unsplash (2.1.0) @@ -442,7 +486,9 @@ GEM zeitwerk (2.5.4) PLATFORMS - ruby + arm64-darwin-21 + x86_64-darwin-21 + x86_64-linux DEPENDENCIES angularjs-rails @@ -509,4 +555,4 @@ RUBY VERSION ruby 2.7.5p203 BUNDLED WITH - 2.3.12 + 2.3.15 diff --git a/app/controllers/admin/communication/websites/posts/curations_controller.rb b/app/controllers/admin/communication/websites/posts/curations_controller.rb index f659841f1e18d50b83ee14baf7ed0ce1c966c68d..04f417d94568e73445600d1a018dcf11f18fb9af 100644 --- a/app/controllers/admin/communication/websites/posts/curations_controller.rb +++ b/app/controllers/admin/communication/websites/posts/curations_controller.rb @@ -6,7 +6,8 @@ class Admin::Communication::Websites::Posts::CurationsController < Admin::Commun def create @curator = Curator.new @website, current_user, curation_params[:url] if @curator.valid? - redirect_to [:edit, :admin, @curator.post], notice: t('admin.successfully_created_html', model: @curator.post.to_s) + redirect_to [:edit, :admin, @curator.post], + notice: t('admin.successfully_created_html', model: @curator.post.to_s) else breadcrumb flash[:alert] = "Erreur lors de la curation" diff --git a/app/controllers/admin/users_controller.rb b/app/controllers/admin/users_controller.rb index ddb1f9b14892952864005cc7807c0495be6273cc..9c856b761d7091cca3cde116bca33238a34f4a60 100644 --- a/app/controllers/admin/users_controller.rb +++ b/app/controllers/admin/users_controller.rb @@ -1,6 +1,7 @@ class Admin::UsersController < Admin::ApplicationController load_and_authorize_resource through: :current_university + has_scope :for_language has_scope :for_role has_scope :for_search_term diff --git a/app/models/communication/website/page/with_kind.rb b/app/models/communication/website/page/with_kind.rb index 22644ce295943ec6ef4268a7ac75c6e47ad6d624..a1b0ea544157ca08e7836300114f825194a96578 100644 --- a/app/models/communication/website/page/with_kind.rb +++ b/app/models/communication/website/page/with_kind.rb @@ -13,6 +13,7 @@ module Communication::Website::Page::WithKind legal_terms: 80, sitemap: 81, privacy_policy: 82, + accessibility: 83, organizations: 90, persons: 100, administrators: 110, diff --git a/app/models/communication/website/with_dependencies.rb b/app/models/communication/website/with_dependencies.rb index 0303b6685b9b6902d0aa4cb7ea1d877b87937c1c..c9939dc2b03d01632982ac5b83df91bb3125443c 100644 --- a/app/models/communication/website/with_dependencies.rb +++ b/app/models/communication/website/with_dependencies.rb @@ -118,6 +118,10 @@ module Communication::Website::WithDependencies true end + def has_accessibility? + true + end + def has_communication_posts? posts.published.any? end diff --git a/app/models/communication/website/with_special_pages.rb b/app/models/communication/website/with_special_pages.rb index 56d01100c365961cf40de6c4fd6bdeb300bcde0b..4e5d446ca103181f78b3c93998b5fc3c32dad9b9 100644 --- a/app/models/communication/website/with_special_pages.rb +++ b/app/models/communication/website/with_special_pages.rb @@ -13,7 +13,7 @@ module Communication::Website::WithSpecialPages def create_missing_special_pages homepage = create_special_page('home') # first level pages with test - ['legal_terms', 'sitemap', 'privacy_policy', 'communication_posts', 'education_programs', 'education_diplomas', 'research_articles', 'research_volumes', 'organizations'].each do |kind| + ['legal_terms', 'sitemap', 'privacy_policy', 'accessibility', 'communication_posts', 'education_programs', 'education_diplomas', 'research_articles', 'research_volumes', 'organizations'].each do |kind| create_special_page(kind, homepage.id) if public_send("has_#{kind}?") end # team pages diff --git a/app/models/university/person/experience.rb b/app/models/university/person/experience.rb index 7a07ecd396a65efa71e56702971532a3a3227802..3cee8c3347cd85fbc792cc0aac2bfa61b3ac4523 100644 --- a/app/models/university/person/experience.rb +++ b/app/models/university/person/experience.rb @@ -29,7 +29,5 @@ class University::Person::Experience < ApplicationRecord belongs_to :person belongs_to :organization, class_name: "University::Organization" - validates :from_year, presence: true - scope :ordered, -> { order(from_year: :desc)} end diff --git a/app/models/university/person/with_experiences.rb b/app/models/university/person/with_experiences.rb index 3de7c0e972a23cacb411d15a733cea149e1e5a2d..45b6cbba52826bf63258092a56f5e6039e9ba5c4 100644 --- a/app/models/university/person/with_experiences.rb +++ b/app/models/university/person/with_experiences.rb @@ -10,8 +10,7 @@ module University::Person::WithExperiences reject_if: :all_blank, allow_destroy: true - # PA FIXME - # validates_associated :experiences + validates_associated :experiences scope :for_alumni_organization, -> (organization_id) { left_joins(:experiences) diff --git a/app/models/user.rb b/app/models/user.rb index 0b7266b7eee47105b9edd65fa93bd81db33a373d..ee8e99f437f8767ad2cf4ffe352c06d4d73742e4 100644 --- a/app/models/user.rb +++ b/app/models/user.rb @@ -65,6 +65,7 @@ class User < ApplicationRecord belongs_to :language scope :ordered, -> { order(:last_name, :first_name) } + scope :for_language, -> (language_id) { where(language_id: language_id) } scope :for_search_term, -> (term) { where(" unaccent(concat(users.first_name, ' ', users.last_name)) ILIKE unaccent(:term) OR diff --git a/app/services/curator.rb b/app/services/curator.rb index 8b56f1a912e21ccf745cc288fde9e03c190760bf..4a0a31cde76dba103154b2dcb2bb23b52737385c 100644 --- a/app/services/curator.rb +++ b/app/services/curator.rb @@ -16,7 +16,7 @@ class Curator protected def create_post! - text = Wordpress.clean_html("#{page.text}<br><a href=\"#{@url}\" target=\"_blank\">Source</a>") + text = Wordpress.clean_html("#{page.text}<p><a href=\"#{@url}\" target=\"_blank\">Source</a></p>") @post = website.posts.create( university: website.university, title: page.title, diff --git a/app/services/filters/admin/users.rb b/app/services/filters/admin/users.rb index 5438038118677358d22fd77657476ee056b5660c..62691ceffc6174f0550cce0442cdbe03df72a762 100644 --- a/app/services/filters/admin/users.rb +++ b/app/services/filters/admin/users.rb @@ -3,6 +3,12 @@ module Filters def initialize(user) super add_search + add :for_language, + ::Language.all.map { |l| { to_s: I18n.t("languages.#{l.iso_code}"), id: l.id } }, + I18n.t( + 'filters.attributes.element', + element: Language.model_name.human.downcase + ) add :for_role, ::User.roles.keys.map { |r| { to_s: I18n.t("activerecord.attributes.user.roles.#{r}"), id: r } }, I18n.t('filters.attributes.role') diff --git a/app/views/admin/communication/blocks/_static.html.erb b/app/views/admin/communication/blocks/_static.html.erb index 22377454bf009046a56668ebf0d883852d96fa1e..f48693db8af3b0f27d902061e6799268d68a02e2 100644 --- a/app/views/admin/communication/blocks/_static.html.erb +++ b/app/views/admin/communication/blocks/_static.html.erb @@ -5,7 +5,7 @@ blocks: @university = about.university %> - template: <%= block.template_kind %> - title: > + title: >- <%= prepare_text_for_static block.title, 3 %> position: <%= block.position %> data: diff --git a/app/views/admin/communication/blocks/templates/call_to_action/_static.html.erb b/app/views/admin/communication/blocks/templates/call_to_action/_static.html.erb index cbc779dcec1065b5351677e4eedcca6cebee80f3..d17eb5d06ecd6cd3890c112d48cfce4dfc78d8fb 100644 --- a/app/views/admin/communication/blocks/templates/call_to_action/_static.html.erb +++ b/app/views/admin/communication/blocks/templates/call_to_action/_static.html.erb @@ -4,8 +4,10 @@ image: id: "<%= block.template.image.blob.id %>" file: "<%= block.template.image.blob.id %>" - alt: <%= prepare_text_for_static block.template.image.alt %> - credit: <%= prepare_text_for_static block.template.image.credit %> + alt: >- + <%= prepare_text_for_static block.template.image.alt, 5 %> + credit: >- + <%= prepare_text_for_static block.template.image.credit, 5 %> <% end %> button: text: >- diff --git a/app/views/admin/communication/blocks/templates/files/_static.html.erb b/app/views/admin/communication/blocks/templates/files/_static.html.erb index cbfb04c22cc65b327b433099652b03f2e2f74168..6a73fcab9406836a14d27bcfd3611eb8285fffbd 100644 --- a/app/views/admin/communication/blocks/templates/files/_static.html.erb +++ b/app/views/admin/communication/blocks/templates/files/_static.html.erb @@ -1,5 +1,6 @@ files: <% block.template.files.each do |file| %> - - title: "<%= file.title %>" + - title: >- + <%= prepare_text_for_static file.title, 6 %> id: "<%= file.blob.id if file.blob %>" <% end %> diff --git a/app/views/admin/education/teachers/_list.html.erb b/app/views/admin/education/teachers/_list.html.erb index d9deb9b99ae6a7c2f3ce31b2884d0c70f2f11d80..cdcbf4649fcda328e908c0d62cc1d5e96c7c04a0 100644 --- a/app/views/admin/education/teachers/_list.html.erb +++ b/app/views/admin/education/teachers/_list.html.erb @@ -3,6 +3,8 @@ <tr> <th><%= University::Person.human_attribute_name('last_name') %></th> <th><%= University::Person.human_attribute_name('first_name') %></th> + <th><%= Education::Program.model_name.human(count: 2) %></th> + <th></th> <th></th> </tr> </thead> @@ -11,9 +13,14 @@ <tr> <td><%= link_to teacher.last_name, admin_education_teacher_path(teacher) %></td> <td><%= link_to teacher.first_name, admin_education_teacher_path(teacher) %></td> + <td><%= teacher.involvements.size %></td> + <td class="p-0"> + <%= kamifusen_tag teacher.best_picture, + width: 40 if teacher.best_picture.attached? %> + </td> <td class="text-end"> <div class="btn-group" role="group"> - <%#= link_to t('edit'), + <%= link_to t('edit'), edit_admin_education_teacher_path(teacher), class: button_classes %> </div> diff --git a/app/views/admin/research/researchers/index.html.erb b/app/views/admin/research/researchers/index.html.erb index d0256588dcffd2d64877dc044571ab30f21803f9..d20f3591baaf0bbd51dbb3315f83e29b768694b8 100644 --- a/app/views/admin/research/researchers/index.html.erb +++ b/app/views/admin/research/researchers/index.html.erb @@ -7,6 +7,7 @@ <tr> <th><%= University::Person.human_attribute_name('name') %></th> <th><%= University::Person.human_attribute_name('first_name') %></th> + <th></th> <th><%= t('research.number_of_articles') %></th> </tr> </thead> @@ -16,6 +17,10 @@ <tr> <td><%= link_to researcher.last_name, admin_research_researcher_path(researcher) %></td> <td><%= link_to researcher.first_name, admin_research_researcher_path(researcher) %></td> + <td class="p-0"> + <%= kamifusen_tag researcher.best_picture, + width: 40 if researcher.best_picture.attached? %> + </td> <td><%= researcher.research_journal_articles.count %></td> </tr> <% end %> diff --git a/app/views/admin/university/alumni/_list.html.erb b/app/views/admin/university/alumni/_list.html.erb index e8676343406419cacc52936259be44191a1fc8ca..212f867b40057810d3ddb5b1ac898737945cfed2 100644 --- a/app/views/admin/university/alumni/_list.html.erb +++ b/app/views/admin/university/alumni/_list.html.erb @@ -3,14 +3,23 @@ <tr> <th><%= University::Person.human_attribute_name('last_name') %></th> <th><%= University::Person.human_attribute_name('first_name') %></th> + <th><%= Education::Cohort.model_name.human(count: 2) %></th> + <th><%= University::Person::Experience.model_name.human(count: 2) %></th> + <th></th> </tr> </thead> <tbody> <% alumni.each do |alumnus| %> <% path = admin_university_alumnus_path(alumnus) %> <tr> - <td><%= link_to alumnus.last_name, path %></td> - <td><%= link_to alumnus.first_name, path %></td> + <td><%= link_to_if can?(:read, alumnus), alumnus.last_name, path %></td> + <td><%= link_to_if can?(:read, alumnus), alumnus.first_name, path %></td> + <td><%= link_to_if can?(:update, alumnus), alumnus.cohorts.size, cohorts_admin_university_alumnus_path(alumnus) %></td> + <td><%= link_to_if can?(:update, alumnus), alumnus.experiences.size, experiences_admin_university_alumnus_path(alumnus) %></td> + <td class="p-0"> + <%= kamifusen_tag alumnus.best_picture, + width: 40 if alumnus.best_picture.attached? %> + </td> </tr> <% end %> </tbody> diff --git a/app/views/admin/university/alumni/show.html.erb b/app/views/admin/university/alumni/show.html.erb index 22ceb9fe5559597262e38e89aeebed86d23083da..fe27cf2c690364bbfd76336dbfa182ef58672feb 100644 --- a/app/views/admin/university/alumni/show.html.erb +++ b/app/views/admin/university/alumni/show.html.erb @@ -28,7 +28,7 @@ <% organization = experience.organization %> <li> <%= link_to_if can?(:read, organization), organization, [:admin, organization] %> - <%= "(#{experience.from_year} - #{experience.to_year.present? ? experience.to_year : t('today')})" %> + <%= "(#{experience.from_year} - #{experience.to_year.present? ? experience.to_year : t('today')})" if experience.from_year %> </li> <% end %> </ul> diff --git a/app/views/admin/users/index.html.erb b/app/views/admin/users/index.html.erb index bda69d5ff4c56faa033a05a8206a563a5a2a6b12..ba72682ee1b08d693970200749dfa7c7ffbe16b1 100644 --- a/app/views/admin/users/index.html.erb +++ b/app/views/admin/users/index.html.erb @@ -11,26 +11,20 @@ <th><%= User.human_attribute_name('first_name') %></th> <th><%= User.human_attribute_name('email') %></th> <th><%= User.human_attribute_name('role') %></th> - <th><%= User.human_attribute_name('language') %></th> <th></th> </tr> </thead> <tbody> <% @users.each do |user| %> <tr> - <td><%= user.last_name %></td> - <td><%= user.first_name %></td> + <td><%= link_to_if can?(:read, user), user.last_name, [:admin, user] %></td> + <td><%= link_to_if can?(:read, user), user.first_name, [:admin, user] %></td> <td><%= link_to user.email, [:admin, user] %></td> <td> <span class="badge bg-secondary"> <%= t("activerecord.attributes.user.roles.#{user.role}") %> </span> </td> - <td> - <span class="badge bg-secondary"> - <%= user.language %> - </span> - </td> <td class="text-end"> <div class="btn-group" role="group"> <%= edit_link user %> diff --git a/config/locales/communication/en.yml b/config/locales/communication/en.yml index bfd4da71d4cf89c484d104a3153abab33cf9d01a..838b4f54374e4b20711d38e8acb8dc04bd4c896a 100644 --- a/config/locales/communication/en.yml +++ b/config/locales/communication/en.yml @@ -365,6 +365,11 @@ en: last_posts: Last posts pages: defaults: + accessibility: + admin_description: accessibility page + description_short: '' + slug: accessibility + title: Accessibility administrators: admin_description: list of members in the administrative team description_short: List of members in the administrative team diff --git a/config/locales/communication/fr.yml b/config/locales/communication/fr.yml index 566db9759de326d54d989d63306c44b5c38a8b60..45fad5ead09d12708acdd1294bc4b38ca68a6d06 100644 --- a/config/locales/communication/fr.yml +++ b/config/locales/communication/fr.yml @@ -383,6 +383,11 @@ fr: last_posts: Dernières actualités pages: defaults: + accessibility: + admin_description: page accessibilité + description_short: '' + slug: accessibilite + title: Accessibilité administrators: admin_description: liste des membres de l'équipe administrative description_short: Liste des membres de l'équipe administrative diff --git a/config/locales/en.yml b/config/locales/en.yml index c2bba1bca1222961a37dcb3a6c62c182e38fa186..87184496fcdebdd063422a2e420cdb847e208adb 100644 --- a/config/locales/en.yml +++ b/config/locales/en.yml @@ -128,17 +128,17 @@ en: title: Image alt: label: Alternative text - hint: This text is important for accessibility + hint: This text is important for accessibility. If the image conveys important information, it must be written here. If the information is already written somewhere else in the page, or if the image is purely decorative, the field must be left empty. Otherwise, it would pollute voice navigation. credit: label: Credit hint: The credit must be present according to copyright or copyleft licenses. remove: Remove image filters: attributes: - date: Filter by Date + date: Filter by date element: Filter by %{element} - kind: Filter by Kind - role: Filter by Role + kind: Filter by kind + role: Filter by role buttons: expand: Filter table submit: Filter diff --git a/config/locales/fr.yml b/config/locales/fr.yml index 824f1bfb57e913b854386c65f5d224b27b9edaff..81430035d31a21e3da34a1b678bcd7f426b0c699 100644 --- a/config/locales/fr.yml +++ b/config/locales/fr.yml @@ -128,17 +128,17 @@ fr: title: Image alt: label: Texte alternatif - hint: Ce texte est essentiel pour l'accessibilité + hint: Ce texte est essentiel pour l'accessibilité. Si l'image donne une information importante, il faut écrire ici cette information. Si l'information est déjà présente ailleurs dans la page, ou si l'image est purement décorative, il faut laisser le texte alternatif vide, pour éviter de polluer la navigation vocale. credit: label: Crédit - hint: Le crédit photo doit être indiqué, dans le respect du droit d'auteur + hint: Le crédit photo doit être indiqué, dans le respect du droit d'auteur. remove: Supprimer l'image filters: attributes: - date: Filtrer par Date + date: Filtrer par date element: Filtrer par %{element} - kind: Filtrer par Type - role: Filtrer par Rôle + kind: Filtrer par type + role: Filtrer par rôle buttons: expand: Filtrer le tableau submit: Filtrer