biovision-base 0.22.180920.0 → 0.34.190331.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (223) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +5 -21
  3. data/app/assets/images/biovision/base/icons/apply.svg +4 -0
  4. data/app/assets/images/biovision/base/icons/components/contact.svg +26 -0
  5. data/app/assets/images/biovision/base/icons/components/registration.svg +17 -0
  6. data/app/assets/images/biovision/base/icons/destroy.svg +11 -8
  7. data/app/assets/images/biovision/base/icons/settings.svg +41 -0
  8. data/app/assets/images/biovision/base/icons/slider/arrow-left.svg +4 -0
  9. data/app/assets/images/biovision/base/icons/slider/arrow-right.svg +4 -0
  10. data/app/assets/images/biovision/base/placeholders/16x9.svg +10 -3
  11. data/app/assets/images/biovision/base/placeholders/1x1.svg +12 -0
  12. data/app/assets/images/biovision/base/placeholders/3x2.svg +10 -3
  13. data/app/assets/javascripts/biovision/base/biovision.js +780 -461
  14. data/app/assets/javascripts/biovision/base/components/carousel.js +123 -0
  15. data/app/assets/javascripts/biovision/base/polyfills.js +149 -0
  16. data/app/assets/stylesheets/biovision/base/admin.scss +85 -46
  17. data/app/assets/stylesheets/biovision/base/admin/components.scss +141 -0
  18. data/app/assets/stylesheets/biovision/base/biovision.scss +149 -33
  19. data/app/assets/stylesheets/biovision/base/buttons/buttons-common.scss +22 -0
  20. data/app/assets/stylesheets/biovision/base/default.scss +6 -6
  21. data/app/assets/stylesheets/biovision/base/default_admin.scss +25 -8
  22. data/app/assets/stylesheets/biovision/base/themes/simple-layout.scss +0 -3
  23. data/app/controllers/admin/editable_pages_controller.rb +6 -4
  24. data/app/controllers/admin/privileges_controller.rb +2 -3
  25. data/app/controllers/admin/settings_controller.rb +52 -0
  26. data/app/controllers/admin/simple_blocks_controller.rb +28 -0
  27. data/app/controllers/admin/users_controller.rb +1 -1
  28. data/app/controllers/agents_controller.rb +4 -4
  29. data/app/controllers/authentication_controller.rb +28 -6
  30. data/app/controllers/browsers_controller.rb +4 -4
  31. data/app/controllers/concerns/authentication.rb +8 -5
  32. data/app/controllers/concerns/entity_priority.rb +3 -0
  33. data/app/controllers/concerns/lockable_entity.rb +6 -3
  34. data/app/controllers/concerns/removable_image.rb +4 -5
  35. data/app/controllers/concerns/toggleable_entity.rb +4 -5
  36. data/app/controllers/editable_pages_controller.rb +14 -8
  37. data/app/controllers/fallback_controller.rb +7 -2
  38. data/app/controllers/feedback_requests_controller.rb +23 -8
  39. data/app/controllers/metrics_controller.rb +3 -3
  40. data/app/controllers/my/profiles_controller.rb +32 -15
  41. data/app/controllers/privilege_groups_controller.rb +4 -4
  42. data/app/controllers/privileges_controller.rb +7 -26
  43. data/app/controllers/simple_blocks_controller.rb +63 -0
  44. data/app/controllers/stored_values_controller.rb +4 -4
  45. data/app/controllers/tokens_controller.rb +4 -4
  46. data/app/controllers/users_controller.rb +8 -3
  47. data/app/helpers/biovision_users_helper.rb +60 -21
  48. data/app/helpers/editable_pages_helper.rb +22 -0
  49. data/app/helpers/languages_helper.rb +3 -0
  50. data/app/helpers/simple_image_helper.rb +66 -0
  51. data/app/mailers/application_mailer.rb +0 -2
  52. data/app/mailers/code_sender.rb +13 -2
  53. data/app/mailers/feedback_mailer.rb +5 -2
  54. data/app/mailers/user_mailer.rb +6 -1
  55. data/app/models/biovision_component.rb +43 -0
  56. data/app/models/biovision_parameter.rb +34 -0
  57. data/app/models/code.rb +22 -7
  58. data/app/models/code_type.rb +9 -1
  59. data/app/models/concerns/flat_priority.rb +50 -0
  60. data/app/models/concerns/nested_priority.rb +58 -0
  61. data/app/models/concerns/required_unique_slug.rb +5 -2
  62. data/app/models/editable_page.rb +49 -37
  63. data/app/models/foreign_site.rb +5 -3
  64. data/app/models/language.rb +15 -37
  65. data/app/models/metric.rb +2 -4
  66. data/app/models/privilege.rb +23 -45
  67. data/app/models/privilege_group.rb +6 -1
  68. data/app/models/simple_block.rb +66 -0
  69. data/app/models/user.rb +29 -26
  70. data/app/models/user_privilege.rb +1 -1
  71. data/app/services/biovision/components/base_component.rb +115 -0
  72. data/app/services/biovision/components/registration_component.rb +98 -0
  73. data/app/services/code_manager.rb +4 -1
  74. data/app/services/code_manager/confirmation.rb +8 -4
  75. data/app/services/code_manager/invitation.rb +9 -5
  76. data/app/services/code_manager/recovery.rb +9 -6
  77. data/app/services/user_manager.rb +5 -4
  78. data/app/services/user_profile_handler.rb +38 -11
  79. data/app/uploaders/avatar_uploader.rb +5 -1
  80. data/app/uploaders/editable_page_image_uploader.rb +4 -6
  81. data/app/uploaders/media_file_uploader.rb +6 -4
  82. data/app/uploaders/media_snapshot_uploader.rb +6 -2
  83. data/app/uploaders/simple_file_uploader.rb +12 -0
  84. data/app/uploaders/simple_image_uploader.rb +75 -0
  85. data/app/views/about/editable.html.erb +1 -1
  86. data/app/views/admin/agents/_filter.html.erb +1 -1
  87. data/app/views/admin/editable_pages/entity/_in_list.html.erb +16 -0
  88. data/app/views/admin/editable_pages/index.html.erb +8 -1
  89. data/app/views/admin/editable_pages/show.html.erb +21 -17
  90. data/app/views/admin/feedback_requests/entity/_in_list.html.erb +9 -1
  91. data/app/views/admin/index/_biovision_base.html.erb +5 -7
  92. data/app/views/admin/index/_components.html.erb +9 -0
  93. data/app/views/admin/index/dashboard/_editorial.html.erb +2 -2
  94. data/app/views/admin/index/dashboard/_settings.html.erb +2 -2
  95. data/app/views/admin/index/index.html.erb +2 -0
  96. data/app/views/admin/privileges/entity/_groups.html.erb +25 -25
  97. data/app/views/admin/privileges/entity/_in_list.html.erb +30 -9
  98. data/app/views/admin/privileges/index.html.erb +6 -1
  99. data/app/views/admin/privileges/show.html.erb +31 -18
  100. data/app/views/admin/settings/component/_new_parameter.html.erb +62 -0
  101. data/app/views/admin/settings/component/_parameters.html.erb +37 -0
  102. data/app/views/admin/settings/component/_setting.html.erb +18 -0
  103. data/app/views/admin/settings/component/_settings.html.erb +31 -0
  104. data/app/views/admin/settings/index.html.erb +27 -0
  105. data/app/views/admin/settings/show.html.erb +42 -0
  106. data/app/views/admin/simple_blocks/_nav_item.html.erb +6 -0
  107. data/app/views/admin/simple_blocks/entity/_in_list.html.erb +23 -0
  108. data/app/views/admin/simple_blocks/index.html.erb +21 -0
  109. data/app/views/admin/simple_blocks/show.html.erb +51 -0
  110. data/app/views/admin/tokens/_filter.html.erb +1 -1
  111. data/app/views/admin/users/_filter.html.erb +1 -1
  112. data/app/views/admin/users/entity/_privilege.html.erb +12 -21
  113. data/app/views/admin/users/entity/_privilege_tree.html.erb +17 -15
  114. data/app/views/admin/users/privileges.html.erb +9 -1
  115. data/app/views/admin/users/search.jbuilder +3 -3
  116. data/app/views/admin/users/show.html.erb +11 -6
  117. data/app/views/agents/_filter.html.erb +22 -22
  118. data/app/views/agents/_form.html.erb +25 -29
  119. data/app/views/application/forbidden.html.erb +9 -0
  120. data/app/views/application/forbidden.jbuilder +3 -0
  121. data/app/views/authentication/_form.html.erb +13 -13
  122. data/app/views/browsers/_form.html.erb +21 -25
  123. data/app/views/editable_blocks/_entity.html.erb +4 -1
  124. data/app/views/editable_pages/_form.html.erb +63 -62
  125. data/app/views/editable_pages/edit.html.erb +1 -1
  126. data/app/views/editable_pages/entity/_metadata.html.erb +4 -4
  127. data/app/views/editable_pages/new.html.erb +3 -3
  128. data/app/views/fallback/show.html.erb +8 -1
  129. data/app/views/feedback_requests/_form.html.erb +76 -52
  130. data/app/views/feedback_requests/create.js.erb +1 -10
  131. data/app/views/index/index/_editable.html.erb +0 -4
  132. data/app/views/metrics/_form.html.erb +38 -36
  133. data/app/views/my/confirmations/show.html.erb +5 -3
  134. data/app/views/my/profiles/closed.html.erb +7 -0
  135. data/app/views/my/profiles/edit/_form.html.erb +9 -9
  136. data/app/views/my/profiles/new.html.erb +9 -1
  137. data/app/views/my/profiles/new/_form.html.erb +22 -1
  138. data/app/views/my/recoveries/show.html.erb +2 -2
  139. data/app/views/privilege_groups/_form.html.erb +48 -21
  140. data/app/views/privileges/_form.html.erb +68 -36
  141. data/app/views/profiles/_profile.html.erb +3 -3
  142. data/app/views/shared/_pagination.jbuilder +7 -5
  143. data/app/views/shared/admin/_breadcrumbs.html.erb +1 -1
  144. data/app/views/shared/forms/_meta_texts.html.erb +3 -3
  145. data/app/views/shared/forms/_priority.html.erb +12 -0
  146. data/app/views/shared/forms/_state_container.html.erb +1 -0
  147. data/app/views/simple_blocks/_empty.html.erb +0 -0
  148. data/app/views/simple_blocks/_form.html.erb +120 -0
  149. data/app/views/simple_blocks/_simple_block.html.erb +26 -0
  150. data/app/views/simple_blocks/edit.html.erb +17 -0
  151. data/app/views/simple_blocks/new.html.erb +15 -0
  152. data/app/views/stored_values/_form.html.erb +57 -28
  153. data/app/views/tokens/_form.html.erb +31 -26
  154. data/app/views/users/_form.html.erb +1 -1
  155. data/config/initializers/carrierwave.rb +7 -2
  156. data/config/locales/common-ru.yml +5 -0
  157. data/config/locales/components-ru.yml +50 -0
  158. data/config/locales/editable-pages-en.yml +2 -0
  159. data/config/locales/editable-pages-ru.yml +50 -7
  160. data/config/locales/editable-pages-sv.yml +2 -0
  161. data/config/locales/feedback-ru.yml +1 -0
  162. data/config/locales/users-en.yml +0 -1
  163. data/config/locales/users-ru.yml +6 -1
  164. data/config/locales/users-sv.yml +0 -1
  165. data/config/routes.rb +32 -6
  166. data/db/migrate/20181217000000_create_biovision_components.rb +80 -0
  167. data/db/migrate/20181217000010_create_metrics.rb +40 -0
  168. data/db/migrate/20181217000015_create_browsers.rb +38 -0
  169. data/db/migrate/20181217000020_create_languages.rb +30 -0
  170. data/db/migrate/20181217000030_create_users.rb +118 -0
  171. data/db/migrate/20181217000035_create_codes.rb +51 -0
  172. data/db/migrate/20181217000040_create_privileges.rb +142 -0
  173. data/db/migrate/20181217000100_create_media_folders.rb +53 -0
  174. data/db/migrate/20181217000110_create_editable_pages.rb +90 -0
  175. data/db/migrate/20181217000200_create_feedback_requests.rb +27 -0
  176. data/db/migrate/20181217121211_add_uuid_to_users.rb +12 -0
  177. data/db/migrate/20181217121212_update_fields181217.rb +29 -0
  178. data/db/migrate/20190311121212_convert_json_columns.rb +47 -0
  179. data/db/migrate/20190324181818_add_data_to_feedback_requests.rb +14 -0
  180. data/db/migrate/20190326120000_create_simple_blocks.rb +31 -0
  181. data/db/{migrate → obsolete_migrations}/20171223333333_amend_foreign_keys.rb +0 -0
  182. data/db/{migrate → obsolete_migrations}/20180117151515_add_language_to_models.rb +0 -0
  183. data/db/{migrate → obsolete_migrations}/20180321000000_add_profile_data_to_users.rb +4 -4
  184. data/db/{migrate → obsolete_migrations}/20180405000000_add_consent_to_users.rb +0 -0
  185. data/db/{migrate → obsolete_migrations}/20180610222222_add_consent_to_feedback_requests.rb +0 -0
  186. data/db/{migrate → obsolete_migrations}/20180612111111_add_administrative_to_privilege.rb +0 -0
  187. data/db/{migrate → obsolete_migrations}/20180619121212_add_image_alt_text_to_editable_page.rb +0 -0
  188. data/db/{migrate → obsolete_migrations}/20180703111111_add_fields_to_editable_blocks.rb +0 -0
  189. data/db/{migrate → obsolete_migrations}/20180722222222_add_active_to_languages.rb +0 -0
  190. data/db/{migrate → obsolete_migrations}/20180725111111_add_referral_link_to_users.rb +0 -0
  191. data/db/obsolete_migrations/20181012222222_add_deletable_to_privileges.rb +19 -0
  192. data/db/obsolete_migrations/20181012222223_convert_stored_values.rb +13 -0
  193. data/db/obsolete_migrations/20181030080808_update_editable_pages_meta.rb +20 -0
  194. data/lib/biovision/base/base_methods.rb +19 -2
  195. data/lib/biovision/base/version.rb +3 -1
  196. data/lib/tasks/users.rake +19 -1
  197. metadata +75 -40
  198. data/app/views/admin/privileges/_list.html.erb +0 -15
  199. data/db/migrate/20170228000000_create_languages.rb +0 -23
  200. data/db/migrate/20170301000001_create_metrics.rb +0 -23
  201. data/db/migrate/20170301000002_create_metric_values.rb +0 -19
  202. data/db/migrate/20170301000101_create_browsers.rb +0 -22
  203. data/db/migrate/20170301000102_create_agents.rb +0 -22
  204. data/db/migrate/20170302000001_create_users.rb +0 -55
  205. data/db/migrate/20170302000003_create_tokens.rb +0 -23
  206. data/db/migrate/20170302000004_create_code_types.rb +0 -20
  207. data/db/migrate/20170302000005_create_codes.rb +0 -24
  208. data/db/migrate/20170302000101_create_privileges.rb +0 -41
  209. data/db/migrate/20170302000102_create_user_privileges.rb +0 -18
  210. data/db/migrate/20170302000103_create_privilege_groups.rb +0 -23
  211. data/db/migrate/20170302000104_create_privilege_group_privileges.rb +0 -24
  212. data/db/migrate/20170320000000_create_editable_pages.rb +0 -52
  213. data/db/migrate/20170425000001_create_foreign_sites.rb +0 -18
  214. data/db/migrate/20170425000002_create_foreign_users.rb +0 -23
  215. data/db/migrate/20170629120000_create_login_attempts.rb +0 -19
  216. data/db/migrate/20170823000001_create_stored_values.rb +0 -19
  217. data/db/migrate/20171202000000_create_media_folders.rb +0 -28
  218. data/db/migrate/20171202000001_create_media_files.rb +0 -27
  219. data/db/migrate/20171211000000_create_feedback_requests.rb +0 -33
  220. data/db/migrate/20180117160000_create_user_languages.rb +0 -17
  221. data/db/migrate/20180622140000_create_link_blocks.rb +0 -29
  222. data/db/migrate/20180622140001_create_link_block_items.rb +0 -23
  223. data/db/migrate/20180627190000_create_editable_blocks.rb +0 -39
@@ -1,10 +1 @@
1
- {
2
- const form = document.getElementById('<%= j(param_from_request(:form_id)) %>');
3
- const fields = form.querySelector('.fields');
4
- const buttons = form.querySelector('.buttons');
5
- const result = form.querySelector('.result');
6
-
7
- fields.classList.add('hidden');
8
- buttons.classList.add('hidden')
9
- result.classList.remove('hidden');
10
- }
1
+ Biovision.switchFormElements('<%= j(param_from_request(:form_id)) %>', '.state-1', '.state-2');
@@ -1,8 +1,4 @@
1
1
  <% unless entity.nil? %>
2
- <% unless entity.title.blank? %>
3
- <h1><%= entity.title %></h1>
4
- <% end %>
5
-
6
2
  <div class="index-editable">
7
3
  <%= raw(entity.body) %>
8
4
  </div>
@@ -1,43 +1,45 @@
1
- <%= render partial: 'shared/list_of_errors', locals: { entity: entity } %>
1
+ <% model_name = entity.class.to_s.underscore %>
2
+ <%= form_with(model: entity, html: { id: "#{model_name}-form" }) do |f| %>
3
+ <%= render partial: 'shared/list_of_errors', locals: { entity: entity } %>
4
+ <dl>
5
+ <dt><%= t('activerecord.attributes.metric.name') %></dt>
6
+ <dd>
7
+ <%= entity.name %>
8
+ </dd>
2
9
 
3
- <%= form_for entity do |f| %>
4
- <dl>
5
- <dt><%= t('activerecord.attributes.metric.name') %></dt>
6
- <dd>
7
- <%= entity.name %>
8
- </dd>
10
+ <dt><%= f.label :description %></dt>
11
+ <dd>
12
+ <%=
13
+ f.text_field(
14
+ :description,
15
+ id: "#{model_name}_description",
16
+ size: nil,
17
+ maxlength: Metric::DESCRIPTION_LIMIT
18
+ )
19
+ %>
20
+ <div class="guideline"><%= t('.guidelines.description') %></div>
21
+ </dd>
9
22
 
10
- <dt><%= f.label :description %></dt>
11
- <dd>
12
- <%= f.text_field :description %>
13
- <div class="guideline"><%= t('.guidelines.description') %></div>
14
- </dd>
23
+ <dt><%= f.label :default_period %></dt>
24
+ <dd>
25
+ <%=
26
+ f.number_field(
27
+ :default_period,
28
+ id: "#{model_name}_default_period",
29
+ in: Metric::PERIOD_RANGE,
30
+ size: 3,
31
+ required: true
32
+ )
33
+ %>
34
+ <div class="guideline"><%= t('.guidelines.default_period') %></div>
35
+ </dd>
15
36
 
16
- <dt><%= f.label :default_period %></dt>
17
- <dd>
18
- <%= f.number_field :default_period, in: Metric::PERIOD_RANGE, size: 3, required: true %>
19
- <div class="guideline"><%= t('.guidelines.default_period') %></div>
20
- </dd>
21
- </dl>
22
-
23
- <ul class="flags">
24
- <li>
25
- <%= f.check_box :incremental %>
26
- <%= f.label :incremental %>
27
- </li>
28
- <li>
29
- <%= f.check_box :start_with_zero %>
30
- <%= f.label :start_with_zero %>
31
- </li>
32
- <li>
33
- <%= f.check_box :show_on_dashboard %>
34
- <%= f.label :show_on_dashboard %>
35
- </li>
36
- </ul>
37
+ <%= render partial: 'shared/forms/entity_flags', locals: { f: f } %>
38
+ </dl>
37
39
 
38
40
  <%= render 'shared/forms/state_container' %>
39
41
 
40
- <div class="buttons">
41
- <%= f.button t(:save), type: :submit %>
42
- </div>
42
+ <div class="buttons">
43
+ <%= f.button t(:save), type: :submit %>
44
+ </div>
43
45
  <% end %>
@@ -3,11 +3,13 @@
3
3
  <article class="profile-content my-confirmation">
4
4
  <h1><%= t('.title') %></h1>
5
5
  <% if current_user&.email_confirmed? %>
6
- <div class="message-box-notice"><%= t('activerecord.attributes.user.email_confirmed') %></div>
6
+ <div class="message-box-notice">
7
+ <%= t('activerecord.attributes.user.email_confirmed') %>
8
+ </div>
7
9
  <% else %>
8
10
  <section id="confirmation-container">
9
11
  <h2><%= t('.got_code') %></h2>
10
- <%= form_tag my_confirmation_path, method: :patch do %>
12
+ <%= form_with url: my_confirmation_path, method: :patch, local: true do %>
11
13
  <dl>
12
14
  <dt>
13
15
  <%= label_tag :code, t('activerecord.attributes.code.body') %>
@@ -35,7 +37,7 @@
35
37
  <% unless current_user.nil? %>
36
38
  <section>
37
39
  <h2><%= t('.no_code') %></h2>
38
- <%= form_tag my_confirmation_path, method: :post do %>
40
+ <%= form_with url: my_confirmation_path, method: :post, local: true do %>
39
41
  <div>
40
42
  <%= button_tag t('.send_code'), type: :submit %>
41
43
  </div>
@@ -0,0 +1,7 @@
1
+ <% content_for :meta_title, t('.title') %>
2
+
3
+ <article>
4
+ <h1><%= t('.heading') %></h1>
5
+
6
+ <div class="message-box-alert"><%= t('.registration_is_closed') %></div>
7
+ </article>
@@ -1,9 +1,9 @@
1
1
  <%=
2
2
  form_with(
3
- url: my_profile_path,
4
- method: :patch,
3
+ url: my_profile_path,
4
+ method: :patch,
5
5
  multipart: true,
6
- id: 'user-form'
6
+ id: 'user-form'
7
7
  ) do
8
8
  %>
9
9
  <%= render partial: 'shared/list_of_errors', locals: { entity: entity } %>
@@ -27,7 +27,7 @@
27
27
  file_field_tag(
28
28
  'user[image]',
29
29
  accept: 'image/jpeg,image/png',
30
- data: { image: 'user-image' }
30
+ data: { image: 'user-image' }
31
31
  )
32
32
  %>
33
33
  </figcaption>
@@ -35,7 +35,7 @@
35
35
  </dd>
36
36
 
37
37
  <dt>
38
- <%= label_tag :user_profile_birthday, t('activerecord.attributes.user.birthday') %>
38
+ <%= label_tag :user_birthday, t('activerecord.attributes.user.birthday') %>
39
39
  </dt>
40
40
  <dd>
41
41
  <%=
@@ -47,7 +47,7 @@
47
47
  %>
48
48
  </dd>
49
49
 
50
- <%= render partial: 'my/profiles/edit/form/profile_data', locals: { data: entity.profile_data } %>
50
+ <%= render partial: 'my/profiles/edit/form/profile_data', locals: { data: entity.data['profile'] || {} } %>
51
51
 
52
52
  <dt>
53
53
  <%= t('.flags') %>
@@ -85,9 +85,9 @@
85
85
  email_field_tag(
86
86
  'user[email]',
87
87
  entity.email,
88
- size: nil,
88
+ size: nil,
89
89
  maxlength: User::EMAIL_LIMIT,
90
- required: true
90
+ required: true
91
91
  )
92
92
  %>
93
93
  </dd>
@@ -100,7 +100,7 @@
100
100
  telephone_field_tag(
101
101
  'user[phone]',
102
102
  entity.phone,
103
- size: nil,
103
+ size: nil,
104
104
  maxlength: User::PHONE_LIMIT
105
105
  )
106
106
  %>
@@ -3,5 +3,13 @@
3
3
  <article class="my-profile-new">
4
4
  <h1><%= t('.heading') %></h1>
5
5
 
6
- <%= render partial: 'my/profiles/new/form', locals: { entity: @entity } %>
6
+ <%=
7
+ render(
8
+ partial: 'my/profiles/new/form',
9
+ locals: {
10
+ entity: @entity,
11
+ component_handler: @handler
12
+ }
13
+ )
14
+ %>
7
15
  </article>
@@ -76,13 +76,34 @@
76
76
  id: "#{model_name}_email",
77
77
  size: nil,
78
78
  maxlength: User::EMAIL_LIMIT,
79
- required: true,
79
+ required: local_assigns[:component_handler] && component_handler.require_email?,
80
80
  data: { check: :email }
81
81
  )
82
82
  %>
83
83
  <div class="check-result-error hidden" data-field="email"></div>
84
84
  <div class="guideline"><%= t('.guidelines.email') %></div>
85
85
  </dd>
86
+
87
+ <% if local_assigns[:component_handler] && component_handler.use_invites? %>
88
+ <dt>
89
+ <%= label_tag :code, t('.invitation_code') %>
90
+ </dt>
91
+ <dd>
92
+ <%=
93
+ text_field_tag(
94
+ :code,
95
+ param_from_request(:code),
96
+ required: component_handler.invite_only?,
97
+ size: nil,
98
+ maxlength: Code::BODY_LIMIT,
99
+ data: {
100
+ check: :code
101
+ }
102
+ )
103
+ %>
104
+ <div class="check-result-error hidden" data-field="code"></div>
105
+ </dd>
106
+ <% end %>
86
107
  </dl>
87
108
 
88
109
  <ul class="flags">
@@ -5,7 +5,7 @@
5
5
 
6
6
  <section>
7
7
  <h2><%= t('.got_code') %></h2>
8
- <%= form_tag my_recovery_path, method: :patch do %>
8
+ <%= form_with url: my_recovery_path, method: :patch, local: true do %>
9
9
  <dl>
10
10
  <dt>
11
11
  <%= label_tag :code, t('activerecord.attributes.code.body') %>
@@ -37,7 +37,7 @@
37
37
 
38
38
  <section>
39
39
  <h2><%= t('.no_code') %></h2>
40
- <%= form_tag my_recovery_path, method: :post do %>
40
+ <%= form_with url: my_recovery_path, method: :post, local: true do %>
41
41
  <dl>
42
42
  <dt><%= label_tag :email, t('activerecord.attributes.user.email') %></dt>
43
43
  <dd><%= email_field_tag :email, param_from_request(:email), required: true %></dd>
@@ -1,28 +1,55 @@
1
- <%= render partial: 'shared/list_of_errors', locals: { entity: entity } %>
1
+ <% model_name = entity.class.to_s.underscore %>
2
+ <%= form_with(model: entity, html: { id: "#{model_name}-form" }) do |f| %>
3
+ <%= render partial: 'shared/list_of_errors', locals: { entity: entity } %>
2
4
 
3
- <%= form_for entity do |f| %>
4
- <dl>
5
- <dt><%= f.label :name %></dt>
6
- <dd>
7
- <%= f.text_field :name, size: nil, maxlenght: PrivilegeGroup::NAME_LIMIT, required: true, placeholder: t('.placeholders.name') %>
8
- </dd>
5
+ <dl>
6
+ <dt><%= f.label :name %></dt>
7
+ <dd>
8
+ <%=
9
+ f.text_field(
10
+ :name,
11
+ id: "#{model_name}_name",
12
+ size: nil,
13
+ maxlenght: PrivilegeGroup::NAME_LIMIT,
14
+ required: true,
15
+ placeholder: t('.placeholders.name')
16
+ )
17
+ %>
18
+ </dd>
9
19
 
10
- <dt><%= f.label :slug %></dt>
11
- <dd>
12
- <%= f.text_field :slug, size: nil, maxlenght: PrivilegeGroup::SLUG_LIMIT, required: true, placeholder: t('.placeholders.slug') %>
13
- <div class="guideline"><%= t('.guidelines.slug') %></div>
14
- </dd>
20
+ <dt><%= f.label :slug %></dt>
21
+ <dd>
22
+ <%=
23
+ f.text_field(
24
+ :slug,
25
+ id: "#{model_name}_slug",
26
+ size: nil,
27
+ maxlenght: PrivilegeGroup::SLUG_LIMIT,
28
+ required: true,
29
+ placeholder: t('.placeholders.slug')
30
+ )
31
+ %>
32
+ <div class="guideline"><%= t('.guidelines.slug') %></div>
33
+ </dd>
15
34
 
16
- <dt><%= f.label :description %></dt>
17
- <dd>
18
- <%= f.text_area :description, cols: 80, rows: 3, maxlenght: PrivilegeGroup::DESCRIPTION_LIMIT %>
19
- <div class="guideline"><%= t('.guidelines.description') %></div>
20
- </dd>
21
- </dl>
35
+ <dt><%= f.label :description %></dt>
36
+ <dd>
37
+ <%=
38
+ f.text_area(
39
+ :description,
40
+ id: "#{model_name}_description",
41
+ cols: 80,
42
+ rows: 3,
43
+ maxlenght: PrivilegeGroup::DESCRIPTION_LIMIT
44
+ )
45
+ %>
46
+ <div class="guideline"><%= t('.guidelines.description') %></div>
47
+ </dd>
48
+ </dl>
22
49
 
23
50
  <%= render 'shared/forms/state_container' %>
24
51
 
25
- <div class="buttons">
26
- <%= f.button t(:save), type: :submit %>
27
- </div>
52
+ <div class="buttons">
53
+ <%= f.button t(:save), type: :submit %>
54
+ </div>
28
55
  <% end %>
@@ -1,46 +1,78 @@
1
- <%= render partial: 'shared/list_of_errors', locals: { entity: entity } %>
2
-
3
- <%= form_for entity do |f| %>
4
- <dl>
5
- <% unless entity.id.nil? %>
6
- <% unless entity.parent_id.nil? %>
7
- <dt><%= t('activerecord.attributes.privilege.parent_id') %></dt>
8
- <dd>
9
- <%= admin_privilege_link(entity.parent) %>
10
- </dd>
11
- <% end %>
1
+ <% model_name = entity.class.to_s.underscore %>
2
+ <%= form_with(model: entity, html: { id: "#{model_name}-form" }) do |f| %>
3
+ <%= render partial: 'shared/list_of_errors', locals: { entity: entity } %>
4
+ <dl>
5
+ <% unless entity.id.nil? %>
6
+ <% unless entity.parent_id.nil? %>
7
+ <dt><%= t('activerecord.attributes.privilege.parent_id') %></dt>
8
+ <dd>
9
+ <%= admin_privilege_link(entity.parent) %>
10
+ </dd>
12
11
  <% end %>
12
+ <% end %>
13
13
 
14
- <dt><%= f.label :name %></dt>
15
- <dd>
16
- <%= f.text_field :name, size: nil, maxlength: Privilege::NAME_LIMIT, required: true %>
17
- <div class="guideline"><%= t('.guidelines.name') %></div>
18
- </dd>
14
+ <dt><%= f.label :name %></dt>
15
+ <dd>
16
+ <%=
17
+ f.text_field(
18
+ :name,
19
+ id: "#{model_name}_name",
20
+ size: nil,
21
+ maxlength: Privilege::NAME_LIMIT,
22
+ required: true
23
+ )
24
+ %>
25
+ <div class="guideline"><%= t('.guidelines.name') %></div>
26
+ </dd>
19
27
 
20
- <dt><%= f.label :slug %></dt>
21
- <dd>
22
- <%= f.text_field :slug, size: nil, maxlength: Privilege::SLUG_LIMIT, required: true, placeholder: t('.placeholders.slug') %>
23
- <div class="guideline"><%= t('.guidelines.slug') %></div>
24
- </dd>
28
+ <dt><%= f.label :slug %></dt>
29
+ <dd>
30
+ <%=
31
+ f.text_field(
32
+ :slug,
33
+ id: "#{model_name}_slug",
34
+ size: nil,
35
+ maxlength: Privilege::SLUG_LIMIT,
36
+ required: true,
37
+ placeholder: t('.placeholders.slug')
38
+ )
39
+ %>
40
+ <div class="guideline"><%= t('.guidelines.slug') %></div>
41
+ </dd>
25
42
 
26
- <dt><%= f.label :priority %></dt>
27
- <dd>
28
- <%= f.number_field :priority, in: Privilege::PRIORITY_RANGE, required: true %>
29
- </dd>
43
+ <dt><%= f.label :priority %></dt>
44
+ <dd>
45
+ <%=
46
+ f.number_field(
47
+ :priority,
48
+ id: "#{model_name}_priority",
49
+ in: Privilege::PRIORITY_RANGE,
50
+ required: true
51
+ )
52
+ %>
53
+ </dd>
30
54
 
31
- <dt><%= f.label :description %></dt>
32
- <dd>
33
- <%= f.text_area :description, cols: 50, rows: 3, maxlength: Privilege::DESCRIPTION_LIMIT %>
34
- <div class="guideline"><%= t('.guidelines.description') %></div>
35
- </dd>
55
+ <dt><%= f.label :description %></dt>
56
+ <dd>
57
+ <%=
58
+ f.text_area(
59
+ :description,
60
+ id: "#{model_name}_description",
61
+ cols: 50,
62
+ rows: 3,
63
+ maxlength: Privilege::DESCRIPTION_LIMIT
64
+ )
65
+ %>
66
+ <div class="guideline"><%= t('.guidelines.description') %></div>
67
+ </dd>
36
68
 
37
- <%= render partial: 'shared/forms/entity_flags', locals: { f: f } %>
38
- </dl>
69
+ <%= render partial: 'shared/forms/entity_flags', locals: { f: f } %>
70
+ </dl>
39
71
 
40
72
  <%= render 'shared/forms/state_container' %>
41
73
 
42
- <div class="buttons">
43
- <%= f.hidden_field :parent_id if entity.id.nil? %>
44
- <%= f.button t(:save), type: :submit %>
45
- </div>
74
+ <div class="buttons">
75
+ <%= f.hidden_field :parent_id if entity.id.nil? %>
76
+ <%= f.button t(:save), type: :submit %>
77
+ </div>
46
78
  <% end %>