decidim-core 0.26.0.rc1 → 0.26.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of decidim-core might be problematic. Click here for more details.

Files changed (119) hide show
  1. checksums.yaml +4 -4
  2. data/app/cells/decidim/activity_cell.rb +3 -0
  3. data/app/cells/decidim/author_cell.rb +1 -0
  4. data/app/cells/decidim/card_m_cell.rb +1 -1
  5. data/app/cells/decidim/diff/diff_mode_dropdown.erb +13 -8
  6. data/app/cells/decidim/diff/diff_mode_html.erb +13 -8
  7. data/app/cells/decidim/diff/show.erb +5 -3
  8. data/app/cells/decidim/endorsement_buttons_cell.rb.2 +211 -0
  9. data/app/cells/decidim/endorsers_list/show.erb +1 -1
  10. data/app/cells/decidim/fingerprint/show.erb +1 -1
  11. data/app/cells/decidim/followers/show.erb +1 -1
  12. data/app/cells/decidim/following/show.erb +2 -2
  13. data/app/cells/decidim/groups/show.erb +1 -1
  14. data/app/cells/decidim/members/show.erb +1 -1
  15. data/app/cells/decidim/profile_sidebar/show.erb +1 -1
  16. data/app/cells/decidim/user_conversation/messages.erb +1 -1
  17. data/app/cells/decidim/user_conversation_cell.rb +4 -0
  18. data/app/cells/decidim/user_conversations/add_conversation_users.erb +1 -1
  19. data/app/cells/decidim/version_cell.rb +1 -1
  20. data/app/cells/decidim/versions_list_cell.rb +1 -1
  21. data/app/cells/decidim/versions_list_item/show.erb +2 -2
  22. data/app/commands/decidim/messaging/reply_to_conversation.rb +4 -1
  23. data/app/commands/decidim/unendorse_resource.rb +5 -4
  24. data/app/controllers/decidim/application_controller.rb +1 -0
  25. data/app/controllers/decidim/components/base_controller.rb +0 -1
  26. data/app/events/decidim/amendable/amendment_base_event.rb +1 -1
  27. data/app/forms/decidim/messaging/message_form.rb +1 -1
  28. data/app/helpers/decidim/endorsable_helper.rb +7 -6
  29. data/app/helpers/decidim/social_share_button_helper.rb +26 -0
  30. data/app/helpers/decidim/twitter_search_helper.rb +14 -0
  31. data/app/models/decidim/moderation.rb +3 -0
  32. data/app/models/decidim/user.rb +0 -9
  33. data/app/models/decidim/user_base_entity.rb +6 -0
  34. data/app/models/decidim/user_group.rb +0 -3
  35. data/app/packs/entrypoints/decidim_core.js +3 -0
  36. data/app/packs/src/decidim/back_to_list.js +26 -0
  37. data/app/packs/src/decidim/dialog_mode.js +11 -99
  38. data/app/packs/src/decidim/dialog_mode.test.js +17 -4
  39. data/app/packs/src/decidim/diff_mode_dropdown.js +3 -3
  40. data/app/packs/src/decidim/dropdowns_menus.js +1 -0
  41. data/app/packs/src/decidim/focus_guard.js +142 -0
  42. data/app/packs/src/decidim/form_filter.js +17 -1
  43. data/app/packs/src/decidim/form_remote.js +38 -0
  44. data/app/packs/src/decidim/index.js +15 -0
  45. data/app/packs/src/decidim/input_character_counter.js +4 -1
  46. data/app/packs/src/decidim/input_emoji.js +38 -6
  47. data/app/packs/src/decidim/input_multiple_mentions.js +19 -0
  48. data/app/packs/src/decidim/vendor/social-share-button.js +174 -0
  49. data/app/packs/stylesheets/decidim/extras/_quill.scss +1 -2
  50. data/app/packs/stylesheets/decidim/modules/_buttons.scss +2 -1
  51. data/app/packs/stylesheets/decidim/modules/_comments.scss +1 -0
  52. data/app/packs/stylesheets/decidim/modules/_forms.scss +6 -1
  53. data/app/packs/stylesheets/decidim/modules/_typography.scss +2 -0
  54. data/app/packs/stylesheets/decidim/utils/_settings.scss +1 -0
  55. data/app/packs/stylesheets/decidim/vendor/_social_share_button.scss +7 -1
  56. data/app/permissions/decidim/permissions.rb +9 -0
  57. data/app/presenters/decidim/menu_item_presenter.rb +9 -1
  58. data/app/views/decidim/account/show.html.erb +1 -1
  59. data/app/views/decidim/application/_collection.html.erb +2 -2
  60. data/app/views/decidim/endorsements/identities.html.erb +1 -1
  61. data/app/views/decidim/groups/new.html.erb +2 -0
  62. data/app/views/decidim/messaging/conversations/_add_conversation_users.html.erb +1 -1
  63. data/app/views/decidim/messaging/conversations/_conversation.html.erb +8 -2
  64. data/app/views/decidim/messaging/conversations/_reply.html.erb +1 -1
  65. data/app/views/decidim/messaging/conversations/_start.html.erb +1 -1
  66. data/app/views/decidim/messaging/conversations/create.js.erb +1 -0
  67. data/app/views/layouts/decidim/_language_chooser.html.erb +9 -2
  68. data/app/views/layouts/decidim/_logo.html.erb +1 -1
  69. data/config/initializers/devise.rb +7 -19
  70. data/config/locales/ar.yml +63 -0
  71. data/config/locales/ca.yml +46 -2
  72. data/config/locales/cs.yml +10 -2
  73. data/config/locales/de.yml +12 -1
  74. data/config/locales/en.yml +9 -0
  75. data/config/locales/es-MX.yml +47 -0
  76. data/config/locales/es-PY.yml +47 -0
  77. data/config/locales/es.yml +2 -0
  78. data/config/locales/eu.yml +6 -0
  79. data/config/locales/fi-plain.yml +48 -0
  80. data/config/locales/fi.yml +10 -0
  81. data/config/locales/fr-CA.yml +16 -0
  82. data/config/locales/fr.yml +41 -25
  83. data/config/locales/gl.yml +51 -0
  84. data/config/locales/hu.yml +111 -0
  85. data/config/locales/it.yml +1 -0
  86. data/config/locales/ja.yml +16 -5
  87. data/config/locales/nl.yml +0 -3
  88. data/config/locales/no.yml +225 -0
  89. data/config/locales/ro-RO.yml +14 -0
  90. data/config/locales/sv.yml +45 -3
  91. data/db/seeds.rb +2 -2
  92. data/lib/decidim/api/functions/user_entity_finder.rb +2 -1
  93. data/lib/decidim/api/functions/user_entity_list.rb +2 -1
  94. data/lib/decidim/content_renderers/link_renderer.rb +1 -1
  95. data/lib/decidim/core/engine.rb +43 -0
  96. data/lib/decidim/core/test/shared_examples/amendable/amendment_accepted_event_examples.rb +0 -1
  97. data/lib/decidim/core/test/shared_examples/amendable/amendment_created_event_examples.rb +0 -1
  98. data/lib/decidim/core/test/shared_examples/amendable/amendment_promoted_event_examples.rb +0 -1
  99. data/lib/decidim/core/test/shared_examples/amendable/amendment_rejected_event_examples.rb +0 -1
  100. data/lib/decidim/core/test/shared_examples/comments_examples.rb +27 -0
  101. data/lib/decidim/core/test/shared_examples/conversations_examples.rb +19 -0
  102. data/lib/decidim/core/test/shared_examples/endorsable.rb +69 -0
  103. data/lib/decidim/core/test/shared_examples/searchable_results_examples.rb +34 -0
  104. data/lib/decidim/core/test.rb +2 -0
  105. data/lib/decidim/core/version.rb +1 -1
  106. data/lib/decidim/endorsable.rb +5 -1
  107. data/lib/decidim/map/autocomplete.rb +12 -5
  108. data/lib/decidim/middleware/rails_cookies.rb +23 -0
  109. data/lib/decidim/resourceable.rb +1 -0
  110. data/lib/decidim/searchable.rb +10 -4
  111. data/lib/decidim/social_share/service.rb +33 -0
  112. data/lib/decidim/social_share/service_registry.rb +63 -0
  113. data/lib/decidim/social_share.rb +45 -0
  114. data/lib/decidim/view_model.rb +0 -1
  115. data/lib/tasks/decidim_webpacker_tasks.rake +4 -10
  116. data/lib/tasks/upgrade/decidim_moderation_tasks.rake +32 -0
  117. metadata +22 -10
  118. data/app/helpers/decidim/filter_params_helper.rb +0 -30
  119. data/config/initializers/mail_previews.rb +0 -5
@@ -0,0 +1,174 @@
1
+ /* eslint-disable complexity, default-case, no-param-reassign, consistent-return */
2
+
3
+ /*
4
+ *
5
+ * Social Share Button
6
+ *
7
+ * Copyright (c) <2012> <Jason Lee> - The MIT license
8
+ * Originally copied fom https://github.com/huacnlee/social-share-button
9
+ * Transformed from Coffescript to Javascipt with decaffeintate
10
+ *
11
+ * We've copied itlocally so it works with webpacker
12
+ *
13
+ * decaffeinate suggestions:
14
+ * DS102: Remove unnecessary code created because of implicit returns
15
+ * DS205: Consider reworking code to avoid use of IIFEs
16
+ * DS207: Consider shorter variations of null checks
17
+ * Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
18
+ */
19
+ window.SocialShareButton = {
20
+ openUrl(url, width, height) {
21
+ if (width === null) {
22
+ width = 640;
23
+ }
24
+ if (height === null) {
25
+ height = 480;
26
+ }
27
+ const left = (screen.width / 2) - (width / 2);
28
+ const top = (screen.height * 0.3) - (height / 2);
29
+ const opt = `width=${width},height=${height},left=${left},top=${top},menubar=no,status=no,location=no`;
30
+ window.open(url, "popup", opt);
31
+ return false;
32
+ },
33
+
34
+ share(el) {
35
+ if (el.getAttribute === null) {
36
+ el = document.querySelector(el);
37
+ }
38
+
39
+ const site = el.getAttribute("data-site");
40
+ const appkey = el.getAttribute("data-appkey") || "";
41
+ const $parent = el.parentNode;
42
+ let title = encodeURIComponent(el.getAttribute(`data-${site}-title`) || $parent.getAttribute("data-title") || "");
43
+ const img = encodeURIComponent($parent.getAttribute("data-img") || "");
44
+ let url = encodeURIComponent($parent.getAttribute("data-url") || "");
45
+ const via = encodeURIComponent($parent.getAttribute("data-via") || "");
46
+ const desc = encodeURIComponent($parent.getAttribute("data-desc") || " ");
47
+
48
+ // tracking click events if google analytics enabled
49
+ const ga = window[window.GoogleAnalyticsObject || "ga"];
50
+ if (typeof ga === "function") {
51
+ ga("send", "event", "Social Share Button", "click", site);
52
+ }
53
+
54
+ if (url.length === 0) {
55
+ url = encodeURIComponent(location.href);
56
+ }
57
+ switch (site) {
58
+ case "email":
59
+ location.href = `mailto:?subject=${title}&body=${url}`;
60
+ break;
61
+ case "weibo":
62
+ this.openUrl(`http://service.weibo.com/share/share.php?url=${url}&type=3&pic=${img}&title=${title}&appkey=${appkey}`, 620, 370);
63
+ break;
64
+ case "twitter": {
65
+ let hashtags = encodeURIComponent(el.getAttribute(`data-${site}-hashtags`) || $parent.getAttribute("data-hashtags") || "");
66
+ let viaStr = "";
67
+ if (via.length > 0) {
68
+ viaStr = `&via=${via}`;
69
+ }
70
+ this.openUrl(`https://twitter.com/intent/tweet?url=${url}&text=${title}&hashtags=${hashtags}${viaStr}`, 650, 300);
71
+ break;
72
+ }
73
+ case "douban":
74
+ this.openUrl(`http://shuo.douban.com/!service/share?href=${url}&name=${title}&image=${img}&sel=${desc}`, 770, 470);
75
+ break;
76
+ case "facebook":
77
+ this.openUrl(`http://www.facebook.com/sharer/sharer.php?u=${url}`, 555, 400);
78
+ break;
79
+ case "qq":
80
+ this.openUrl(`http://sns.qzone.qq.com/cgi-bin/qzshare/cgi_qzshare_onekey?url=${url}&title=${title}&pics=${img}&summary=${desc}&site=${appkey}`);
81
+ break;
82
+ case "google_bookmark":
83
+ this.openUrl(`https://www.google.com/bookmarks/mark?op=edit&output=popup&bkmk=${url}&title=${title}`);
84
+ break;
85
+ case "delicious":
86
+ this.openUrl(`https://del.icio.us/save?url=${url}&title=${title}&jump=yes&pic=${img}`);
87
+ break;
88
+ case "pinterest":
89
+ this.openUrl(`http://www.pinterest.com/pin/create/button/?url=${url}&media=${img}&description=${title}`);
90
+ break;
91
+ case "linkedin":
92
+ this.openUrl(`https://www.linkedin.com/shareArticle?mini=true&url=${url}&title=${title}&summary=${desc}`);
93
+ break;
94
+ case "xing":
95
+ this.openUrl(`https://www.xing.com/spi/shares/new?url=${url}`);
96
+ break;
97
+ case "vkontakte":
98
+ this.openUrl(`http://vk.com/share.php?url=${url}&title=${title}&image=${img}`);
99
+ break;
100
+ case "odnoklassniki":
101
+ this.openUrl(`https://connect.ok.ru/offer?url=${url}&title=${title}&description=${desc}&imageUrl=${img}`);
102
+ break;
103
+ case "wechat":
104
+ if (!window.SocialShareWeChatButton) {
105
+ throw new Error("You should require social-share-button/wechat to your application.js");
106
+ }
107
+ window.SocialShareWeChatButton.qrcode({
108
+ url: decodeURIComponent(url),
109
+ header: el.getAttribute("title"),
110
+ footer: el.getAttribute("data-wechat-footer")
111
+ });
112
+ break;
113
+
114
+ case "tumblr": {
115
+ let getTumblrExtra = (param) => {
116
+ const cutomData = el.getAttribute(`data-${param}`);
117
+ if (cutomData) {
118
+ return encodeURIComponent(cutomData);
119
+ }
120
+ };
121
+
122
+ let tumblrParams = () => {
123
+ const path = getTumblrExtra("type") || "link";
124
+
125
+ const params = (() => {
126
+ switch (path) {
127
+ case "text": {
128
+ title = getTumblrExtra("title") || title;
129
+ return `title=${title}`;
130
+ }
131
+ case "photo": {
132
+ title = getTumblrExtra("caption") || title;
133
+ let source = getTumblrExtra("source") || img;
134
+ return `caption=${title}&source=${source}`;
135
+ }
136
+ case "quote": {
137
+ let quote = getTumblrExtra("quote") || title;
138
+ let source = getTumblrExtra("source") || "";
139
+ return `quote=${quote}&source=${source}`;
140
+ }
141
+ // actually, it's a link clause
142
+ default: {
143
+ title = getTumblrExtra("title") || title;
144
+ url = getTumblrExtra("url") || url;
145
+ return `name=${title}&url=${url}`;
146
+ }} })();
147
+
148
+ return `/${path}?${params}`;
149
+ };
150
+
151
+ this.openUrl(`http://www.tumblr.com/share${tumblrParams()}`);
152
+ break;
153
+ }
154
+ case "reddit":
155
+ this.openUrl(`http://www.reddit.com/submit?url=${url}&newwindow=1`, 555, 400);
156
+ break;
157
+ case "hacker_news":
158
+ this.openUrl(`http://news.ycombinator.com/submitlink?u=${url}&t=${title}`, 770, 500);
159
+ break;
160
+ case "telegram":
161
+ this.openUrl(`https://telegram.me/share/url?text=${title}&url=${url}`);
162
+ break;
163
+ case "whatsapp_app": {
164
+ let whatsappAppUrl = `whatsapp://send?text=${title}%0A${url}`;
165
+ window.open(whatsappAppUrl, "_top");
166
+ break;
167
+ }
168
+ case "whatsapp_web":
169
+ this.openUrl(`https://web.whatsapp.com/send?text=${title}%0A${url}`);
170
+ break;
171
+ }
172
+ return false;
173
+ }
174
+ };
@@ -13,8 +13,7 @@
13
13
  }
14
14
 
15
15
  .ql-reset-decidim{
16
- display: flex;
17
- flex-direction: column;
16
+ display: inline;
18
17
  padding: 0;
19
18
  white-space: inherit;
20
19
  }
@@ -372,7 +372,7 @@
372
372
  .link{
373
373
  cursor: pointer;
374
374
  color: var(--secondary);
375
- font-weight: 600;
375
+ font-weight: $anchor-font-weight;
376
376
 
377
377
  &:hover{
378
378
  color: $anchor-color-hover;
@@ -384,6 +384,7 @@
384
384
  .link-alt{
385
385
  cursor: pointer;
386
386
  color: $anchor-color;
387
+ font-weight: $anchor-font-weight;
387
388
 
388
389
  &:hover{
389
390
  color: $anchor-color-hover;
@@ -31,6 +31,7 @@ $comment-form-bg: $light-gray;
31
31
  display: flex;
32
32
 
33
33
  .comment__edited,
34
+ .comment__moderated,
34
35
  .comment__deleted{
35
36
  font-style: italic;
36
37
  color: $muted;
@@ -135,13 +135,18 @@ input[type="radio"]{
135
135
  }
136
136
 
137
137
  &__trigger{
138
+ position: relative;
139
+ top: -$form-spacing;
140
+ }
141
+
142
+ &__button{
138
143
  position: absolute;
139
144
  bottom: $global-margin * .5;
140
145
  right: $global-margin;
141
146
  cursor: pointer;
142
147
  }
143
148
 
144
- &__trigger svg{
149
+ &__button svg{
145
150
  width: 1em;
146
151
  }
147
152
  }
@@ -9,6 +9,7 @@ input{
9
9
 
10
10
  a{
11
11
  color: $anchor-color;
12
+ font-weight: $anchor-font-weight;
12
13
 
13
14
  &:hover{
14
15
  color: $anchor-color-hover;
@@ -89,6 +90,7 @@ button{
89
90
 
90
91
  .heading-small{
91
92
  font-size: 1rem;
93
+ line-height: $header-lineheight;
92
94
  }
93
95
 
94
96
  hr{
@@ -206,6 +206,7 @@ $anchor-outline-focus: 1px dotted rgba(black, .5);
206
206
  $anchor-outline-offset: 2px;
207
207
  $anchor-text-decoration: none;
208
208
  $anchor-text-decoration-hover: none;
209
+ $anchor-font-weight: $global-weight-normal;
209
210
  $hr-width: $global-width;
210
211
  $hr-border: 1px solid $medium-gray;
211
212
  $hr-margin: 6rem auto 5rem;
@@ -1,4 +1,10 @@
1
- // From social-share-button gem
1
+ //
2
+ // Social Share Button
3
+ //
4
+ // Copyright (c) <2012> <Jason Lee> - The MIT license
5
+ // Originally copied fom https://github.com/huacnlee/social-share-button
6
+ // Adapted to Decidim assets pipeline
7
+ //
2
8
 
3
9
  .social-share-button .ssb-icon{
4
10
  background-position: center center;
@@ -10,6 +10,8 @@ module Decidim
10
10
  component_public_action?
11
11
  search_scope_action?
12
12
 
13
+ public_report_content_action?
14
+
13
15
  return permission_action unless user
14
16
 
15
17
  user_manager_permissions
@@ -28,6 +30,13 @@ module Decidim
28
30
 
29
31
  private
30
32
 
33
+ def public_report_content_action?
34
+ return unless permission_action.action == :create &&
35
+ permission_action.subject == :moderation
36
+
37
+ allow!
38
+ end
39
+
31
40
  def read_public_pages_action?
32
41
  return unless permission_action.subject == :public_page &&
33
42
  permission_action.action == :read
@@ -27,7 +27,7 @@ module Decidim
27
27
 
28
28
  def render
29
29
  content_tag :li, class: link_wrapper_classes do
30
- output = [link_to(composed_label, url)]
30
+ output = [link_to(composed_label, url, link_options)]
31
31
  output.push(@view.send(:simple_menu, @menu_item.submenu).render) if @menu_item.submenu
32
32
 
33
33
  safe_join(output)
@@ -36,6 +36,14 @@ module Decidim
36
36
 
37
37
  private
38
38
 
39
+ def link_options
40
+ if is_active_link?(url, active)
41
+ { aria: { current: "page" } }
42
+ else
43
+ {}
44
+ end
45
+ end
46
+
39
47
  def composed_label
40
48
  icon_name.present? ? icon(icon_name) + label : label
41
49
  end
@@ -30,7 +30,7 @@
30
30
  <% else %>
31
31
  <% if current_organization.sign_in_enabled? %>
32
32
  <p>
33
- <a data-toggle="passwordChange" class="change-password" href="#passwordChange"><%= t ".change_password" %></a>
33
+ <button type="button" data-toggle="passwordChange" class="link change-password"><%= t ".change_password" %></button>
34
34
  </p>
35
35
  <div id="passwordChange" class="toggle-show" data-toggler=".is-expanded">
36
36
  <%= render partial: "password_fields", locals: { form: f } %>
@@ -1,11 +1,11 @@
1
1
  <% unless attachment_collection.unused? %>
2
2
  <div class="docs__container">
3
- <span data-toggle="docs-collection-<%= attachment_collection.id %>"><%= icon "caret-right", class: "icon--small", role: "img", "aria-hidden": true %>&nbsp;
3
+ <button type="button" data-toggle="docs-collection-<%= attachment_collection.id %>"><%= icon "caret-right", class: "icon--small", role: "img", "aria-hidden": true %>&nbsp;
4
4
  <strong><%= translated_attribute(attachment_collection.name) %></strong>
5
5
 
6
6
  <% attachment_collection_documents_count = attachment_collection.attachments.select(&:document?).count %>
7
7
  <small>(<%= attachment_collection_documents_count %> <%= t("decidim.application.collection.documents", count: attachment_collection_documents_count) %>)</small>
8
- </span>
8
+ </button>
9
9
 
10
10
  <div id="docs-collection-<%= attachment_collection.id %>" class="docs__content hide" data-toggler=".hide">
11
11
  <p><%= translated_attribute(attachment_collection.description) %></p>
@@ -1,5 +1,5 @@
1
1
  <div class="reveal__header reveal__header--nomargin reveal__bg p-s">
2
- <h6 class="heading6 m-none"><%= t ".select_identity" %></h6>
2
+ <h6 class="heading6 m-none reveal__title"><%= t ".select_identity" %></h6>
3
3
  </div>
4
4
  <ul class="reveal__list">
5
5
  <%= render_endorsement_identity(resource, current_user) %>
@@ -1,3 +1,5 @@
1
+ <% add_decidim_page_title(t(".new_user_group")) %>
2
+
1
3
  <div class="wrapper">
2
4
  <div class="row collapse">
3
5
  <div class="row collapse">
@@ -2,7 +2,7 @@
2
2
  <div class="wrapper wrapper--inner">
3
3
  <div class="row">
4
4
  <div class="large-12">
5
- <h2 id="modalTitle"> <%= t(".modal_title") %> </h2>
5
+ <h2 id="modalTitle" class="reveal__title"><%= t(".modal_title") %></h2>
6
6
  </div>
7
7
  </div>
8
8
  <div class="row">
@@ -14,10 +14,16 @@
14
14
  </li>
15
15
  <li class="card-data__item card--list__item card-data__item--expand absolutes">
16
16
  <div class="mr-s">
17
+ <% if conversation.messages.last.decidim_sender_id == current_user.id %>
18
+ <%= t("to", scope: "decidim.messaging.conversations.index") %>:
19
+ <% else %>
20
+ <%= t("from", scope: "decidim.messaging.conversations.index") %>:
21
+ <% end %>
22
+
17
23
  <% if conversation.interlocutors(current_user).count == 1 %>
18
- <%= t("from", scope: "decidim.messaging.conversations.index") %>: <%= conversation_name_for(conversation.interlocutors(current_user)) %>
24
+ <%= conversation_name_for(conversation.interlocutors(current_user)) %>
19
25
  <% else %>
20
- <%= t("from", scope: "decidim.messaging.conversations.index") %>: <strong><%= username_list(conversation.interlocutors(current_user), shorten: true).html_safe %></strong>
26
+ <strong><%= username_list(conversation.interlocutors(current_user), shorten: true).html_safe %></strong>
21
27
  <% end %>
22
28
  <br>
23
29
  <span class="muted">
@@ -3,7 +3,7 @@
3
3
  <%= t(".title") %>
4
4
  </h2>
5
5
 
6
- <%= form_for form, url: decidim.conversation_path(conversation.id), method: :put, remote: true do |f| %>
6
+ <%= decidim_form_for form, url: decidim.conversation_path(conversation.id), method: :put, remote: true do |f| %>
7
7
  <%= f.label :body, nil, class: "show-for-sr" %>
8
8
  <%= f.text_area :body, label: false, rows: 4, required: true, placeholder: t(".placeholder") %>
9
9
 
@@ -5,7 +5,7 @@
5
5
  <%= t(".title") %>
6
6
  </h2>
7
7
 
8
- <%= form_for form, url: decidim.conversations_path, remote: true do |f| %>
8
+ <%= decidim_form_for form, url: decidim.conversations_path, remote: true do |f| %>
9
9
  <%= form_required_explanation %>
10
10
 
11
11
  <% @form.recipient.each do |recipient| %>
@@ -1,2 +1,3 @@
1
1
  $("#messages").append("<%= j(render "messages", sender: conversation.messages.first.sender, messages: [conversation.messages.first]).html_safe %>");
2
2
  $(".add-message").replaceWith("<%= j(render "reply", form: form, conversation: conversation).html_safe %>");
3
+ $("#new_message_").foundation();
@@ -7,10 +7,17 @@
7
7
  data-close-on-click="true"
8
8
  role="menubar">
9
9
  <li class="is-dropdown-submenu-parent" role="presentation">
10
- <%= link_to t("name", scope: "locale"), "#language-chooser-menu", id: "language-chooser-control", "aria-label": t("layouts.decidim.language_chooser.choose_language"), "aria-controls": "language-chooser-menu", "aria-haspopup": "menu", role: "menuitem" %>
10
+ <%= link_to "#language-chooser-menu", id: "language-chooser-control", "aria-controls": "language-chooser-menu", "aria-haspopup": "menu", role: "menuitem" do %>
11
+ <span aria-hidden="true"><%= t("name", scope: "locale") %></span>
12
+ <span class="show-for-sr">
13
+ <% available_locales.each do |locale| %>
14
+ <span lang="<%= locale %>"><%= I18n.with_locale(locale) { t("layouts.decidim.language_chooser.choose_language") } %></span>
15
+ <% end %>
16
+ </span>
17
+ <% end %>
11
18
  <ul class="menu is-dropdown-submenu" id="language-chooser-menu" role="menu" aria-labelledby="language-chooser-control">
12
19
  <% (available_locales - [I18n.locale.to_s]).each do |locale| %>
13
- <li lang="<%= locale %>" role="presentation"><%= link_to locale_name(locale), decidim.locale_path(locale: locale), method: :post, role: "menuitem" %></li>
20
+ <li role="presentation"><%= link_to locale_name(locale), decidim.locale_path(locale: locale), method: :post, role: "menuitem", lang: locale %></li>
14
21
  <% end %>
15
22
  </ul>
16
23
  </li>
@@ -1,5 +1,5 @@
1
1
  <% if organization %>
2
- <%= link_to decidim.root_url(host: organization.host), title: t("logo", scope: "decidim.accessibility", organization: organization.name) do %>
2
+ <%= link_to decidim.root_url(host: organization.host), "aria-label": t("front_page_link", scope: "decidim.accessibility") do %>
3
3
  <% if organization.logo.attached? %>
4
4
  <%= image_tag organization.attached_uploader(:logo).variant_path(:medium), alt: t("logo", scope: "decidim.accessibility", organization: organization.name) %>
5
5
  <% else %>
@@ -9,6 +9,13 @@ class RandomStalling < Devise::FailureApp
9
9
  sleep rand * 5
10
10
  super
11
11
  end
12
+
13
+ protected
14
+
15
+ def i18n_options(options)
16
+ options[:locale] = session[:user_locale]
17
+ super
18
+ end
12
19
  end
13
20
 
14
21
  Devise.setup do |config|
@@ -19,12 +26,6 @@ Devise.setup do |config|
19
26
  # by default. You can change it below and use your own secret key.
20
27
  # config.secret_key = 'e1f4e9899fb5e8b3123950b19cd0f6d22ecaa8c7fb792b6db5a939edc2b3bab722d06a6a46345ee9bf12caa0178408d6134ea92ed778977b8a7ed1007a0c6dbe'
21
28
 
22
- # ==> Mailer Configuration
23
- # Configure the e-mail address which will be shown in Devise::Mailer,
24
- # note that it will be overwritten if you use your own mailer class
25
- # with default "from" parameter.
26
- config.mailer_sender = Decidim.config.mailer_sender
27
-
28
29
  # Configure the class responsible to send e-mails.
29
30
  config.mailer = "Decidim::DecidimDeviseMailer"
30
31
 
@@ -174,14 +175,6 @@ Devise.setup do |config|
174
175
  # Default: true
175
176
  config.allow_insecure_sign_in_after_accept = true
176
177
 
177
- # ==> Configuration for :confirmable
178
- # A period that the user is allowed to access the website even without
179
- # confirming their account. For instance, if set to 2.days, the user will be
180
- # able to access the website for two days without confirming their account,
181
- # access will be blocked just in the third day. Default is 0.days, meaning
182
- # the user cannot access the website without confirming their account.
183
- config.allow_unconfirmed_access_for = Decidim.unconfirmed_access_for
184
-
185
178
  # A period that the user is allowed to confirm their account before their
186
179
  # token becomes invalid. For example, if set to 3.days, the user can confirm
187
180
  # their account within 3 days after the mail was sent, but on the fourth day
@@ -222,11 +215,6 @@ Devise.setup do |config|
222
215
  # to give user feedback and not to assert the e-mail validity.
223
216
  config.email_regexp = /\A[^@\s]+@[^@\s]+\z/
224
217
 
225
- # ==> Configuration for :timeoutable
226
- # The time you want to timeout the user session without activity. After this
227
- # time the user will be asked for credentials again. Default is 30 minutes.
228
- config.timeout_in = Decidim.config.expire_session_after
229
-
230
218
  # ==> Configuration for :lockable
231
219
  # Defines which strategy will be used to lock an account.
232
220
  # :failed_attempts = Locks an account after a number of failed attempts to sign in.