biovision 0.1.210414.0 → 0.12.211128.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (217) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +50 -40
  3. data/app/assets/stylesheets/biovision/admin/components/users.scss +4 -0
  4. data/app/assets/stylesheets/biovision/admin/components.scss +10 -0
  5. data/app/assets/stylesheets/biovision/admin/layout.scss +34 -8
  6. data/app/assets/stylesheets/biovision/biovision.scss +64 -26
  7. data/app/assets/stylesheets/biovision/components/carousel.scss +24 -24
  8. data/app/assets/stylesheets/biovision/components/filters.scss +39 -0
  9. data/app/assets/stylesheets/biovision/components/forms.scss +56 -10
  10. data/app/assets/stylesheets/biovision/components/quick_search.scss +24 -0
  11. data/app/assets/stylesheets/biovision/components.scss +1 -0
  12. data/app/assets/stylesheets/biovision/default.scss +4 -4
  13. data/app/assets/stylesheets/biovision/themes/default_theme/components/users/dashboard.scss +4 -0
  14. data/app/assets/stylesheets/biovision/themes/default_theme/components/users.scss +1 -0
  15. data/app/assets/stylesheets/biovision/themes/default_theme/layout/footer.scss +3 -0
  16. data/app/assets/stylesheets/biovision/themes/default_theme/layout/header.scss +12 -0
  17. data/app/assets/stylesheets/biovision/themes/default_theme/layout.scss +6 -3
  18. data/app/assets/stylesheets/biovision/themes/default_theme.scss +0 -1
  19. data/app/assets/stylesheets/biovision/vars.scss +5 -0
  20. data/app/controllers/admin/biovision_components_controller.rb +10 -0
  21. data/app/controllers/admin/components_controller.rb +33 -83
  22. data/app/controllers/admin/dynamic_pages_controller.rb +1 -1
  23. data/app/controllers/admin/index_controller.rb +8 -2
  24. data/app/controllers/admin/navigation_groups_controller.rb +31 -0
  25. data/app/controllers/admin/tokens_controller.rb +15 -0
  26. data/app/controllers/admin/users_controller.rb +35 -4
  27. data/app/controllers/admin_controller.rb +2 -9
  28. data/app/controllers/concerns/component_stories.rb +22 -0
  29. data/app/controllers/concerns/crud_entities.rb +23 -15
  30. data/app/controllers/concerns/my_crud_entities.rb +146 -0
  31. data/app/controllers/concerns/processed_forms.rb +28 -0
  32. data/app/controllers/concerns/restricted_access.rb +37 -0
  33. data/app/controllers/contact_controller.rb +1 -1
  34. data/app/controllers/errors_controller.rb +37 -0
  35. data/app/controllers/my/components_controller.rb +21 -0
  36. data/app/controllers/my/index_controller.rb +1 -3
  37. data/app/controllers/my/profiles_controller.rb +2 -0
  38. data/app/controllers/oembed_controller.rb +12 -0
  39. data/app/controllers/profile_controller.rb +2 -0
  40. data/app/controllers/users_controller.rb +2 -0
  41. data/app/helpers/biovision_components_helper.rb +7 -3
  42. data/app/helpers/biovision_helper.rb +33 -34
  43. data/app/helpers/entity_helper.rb +77 -0
  44. data/app/helpers/my_helper.rb +34 -0
  45. data/app/lib/biovision/components/base/component_parameters.rb +13 -2
  46. data/app/lib/biovision/components/base/component_privileges.rb +28 -18
  47. data/app/lib/biovision/components/base/component_settings.rb +8 -0
  48. data/app/lib/biovision/components/base/component_stories.rb +30 -0
  49. data/app/lib/biovision/components/base/entity_links.rb +38 -0
  50. data/app/lib/biovision/components/base/image_handling.rb +33 -0
  51. data/app/lib/biovision/components/base_component.rb +20 -49
  52. data/app/lib/biovision/components/contact_component.rb +5 -1
  53. data/app/lib/biovision/components/content/oembed/receiver.rb +98 -0
  54. data/app/lib/biovision/components/content/oembed/twitter_receiver.rb +20 -0
  55. data/app/lib/biovision/components/content/oembed/vimeo_receiver.rb +20 -0
  56. data/app/lib/biovision/components/content/oembed/youtube_receiver.rb +20 -0
  57. data/app/lib/biovision/components/content_component.rb +46 -9
  58. data/app/lib/biovision/components/track_component.rb +1 -1
  59. data/app/lib/biovision/components/users_component.rb +34 -2
  60. data/app/lib/biovision/helpers/data_helper.rb +70 -0
  61. data/app/lib/biovision/helpers/export_helper.rb +97 -0
  62. data/app/lib/biovision/migrations/component_migration.rb +56 -0
  63. data/app/lib/biovision/stories/component_story.rb +55 -0
  64. data/app/mailers/feedback_mailer.rb +14 -0
  65. data/app/models/biovision_component.rb +17 -1
  66. data/app/models/browser.rb +1 -1
  67. data/app/models/code.rb +5 -5
  68. data/app/models/concerns/checkable.rb +2 -1
  69. data/app/models/concerns/has_uploaded_file.rb +26 -0
  70. data/app/models/concerns/simple_tag.rb +30 -0
  71. data/app/models/concerns/toggleable.rb +2 -1
  72. data/app/models/concerns/tree_structure.rb +4 -1
  73. data/app/models/contact_method.rb +1 -1
  74. data/app/models/contact_type.rb +1 -1
  75. data/app/models/dynamic_block.rb +1 -1
  76. data/app/models/dynamic_page.rb +3 -1
  77. data/app/models/feedback_message.rb +7 -1
  78. data/app/models/feedback_response.rb +2 -2
  79. data/app/models/metric.rb +4 -0
  80. data/app/models/navigation_group.rb +11 -1
  81. data/app/models/oembed_domain.rb +25 -0
  82. data/app/models/oembed_link.rb +19 -0
  83. data/app/models/oembed_receiver.rb +15 -0
  84. data/app/models/role.rb +42 -12
  85. data/app/models/simple_image.rb +30 -3
  86. data/app/models/simple_image_tag.rb +1 -16
  87. data/app/models/token.rb +6 -2
  88. data/app/models/uploaded_file.rb +62 -0
  89. data/app/models/uploaded_file_tag.rb +15 -0
  90. data/app/models/uploaded_file_tag_file.rb +13 -0
  91. data/app/models/user.rb +35 -10
  92. data/app/models/user_role.rb +0 -1
  93. data/app/uploaders/simple_file_uploader.rb +2 -6
  94. data/app/uploaders/simple_image_uploader.rb +10 -21
  95. data/app/uploaders/uploaders/path_slug.rb +22 -0
  96. data/app/views/admin/agents/index.html.erb +1 -1
  97. data/app/views/admin/biovision_components/_nav_item.html.erb +6 -0
  98. data/app/views/admin/biovision_components/entity/_in_list.html.erb +12 -0
  99. data/app/views/admin/biovision_components/index.html.erb +11 -0
  100. data/app/views/admin/components/_list.html.erb +1 -1
  101. data/app/views/admin/components/entity/_links.html.erb +31 -21
  102. data/app/views/admin/components/links/_base.html.erb +1 -0
  103. data/app/views/admin/components/settings/_settings.html.erb +3 -3
  104. data/app/views/admin/components/settings.html.erb +2 -1
  105. data/app/views/admin/dynamic_blocks/_form.html.erb +1 -1
  106. data/app/views/admin/dynamic_blocks/entity/_in_list.html.erb +8 -6
  107. data/app/views/admin/dynamic_blocks/index.html.erb +6 -4
  108. data/app/views/admin/dynamic_blocks/show.html.erb +9 -7
  109. data/app/views/admin/dynamic_pages/_dynamic_page.jbuilder +18 -0
  110. data/app/views/admin/dynamic_pages/entity/_in_list.html.erb +6 -4
  111. data/app/views/admin/dynamic_pages/entity/_in_search.html.erb +7 -0
  112. data/app/views/admin/dynamic_pages/index.html.erb +6 -4
  113. data/app/views/admin/dynamic_pages/search.jbuilder +4 -0
  114. data/app/views/admin/dynamic_pages/show.html.erb +2 -2
  115. data/app/views/admin/index/index.html.erb +7 -5
  116. data/app/views/admin/ip_addresses/index.html.erb +2 -2
  117. data/app/views/admin/navigation_group_pages/entity/_in_list.html.erb +26 -0
  118. data/app/views/admin/navigation_groups/entity/_dynamic_pages.html.erb +38 -0
  119. data/app/views/admin/navigation_groups/entity/_in_list.html.erb +7 -5
  120. data/app/views/admin/navigation_groups/index.html.erb +6 -4
  121. data/app/views/admin/navigation_groups/show.html.erb +16 -3
  122. data/app/views/admin/tokens/_form.html.erb +31 -0
  123. data/app/views/admin/tokens/_nav_item.html.erb +6 -0
  124. data/app/views/admin/tokens/entity/_in_list.html.erb +27 -0
  125. data/app/views/admin/tokens/index.html.erb +11 -0
  126. data/app/views/admin/tokens/show.html.erb +26 -0
  127. data/app/views/admin/users/_user.jbuilder +18 -0
  128. data/app/views/admin/users/entity/_fields.html.erb +1 -1
  129. data/app/views/admin/users/entity/_in_list.html.erb +3 -3
  130. data/app/views/admin/users/entity/_in_search.html.erb +18 -0
  131. data/app/views/admin/users/index.html.erb +13 -4
  132. data/app/views/admin/users/roles/_component.html.erb +22 -0
  133. data/app/views/admin/users/roles.html.erb +23 -0
  134. data/app/views/admin/users/search.jbuilder +4 -0
  135. data/app/views/admin/users/show.html.erb +28 -10
  136. data/app/views/admin/widgets/_filters.html.erb +20 -0
  137. data/app/views/admin/widgets/_quick_search.html.erb +13 -0
  138. data/app/views/admin/widgets/filters/_flag.html.erb +15 -0
  139. data/app/views/admin/widgets/filters/_text.html.erb +7 -0
  140. data/app/views/application/unauthorized.html.erb +4 -1
  141. data/app/views/components/content/_dynamic_page.html.erb +6 -10
  142. data/app/views/components/content/_dynamic_page_content.html.erb +14 -0
  143. data/app/views/components/users/_login_form.html.erb +1 -0
  144. data/app/views/contact/_form.html.erb +1 -1
  145. data/app/views/errors/error.html.erb +1 -0
  146. data/app/views/feedback_mailer/new_feedback_request.html.erb +11 -0
  147. data/app/views/feedback_mailer/new_feedback_request.text.erb +6 -0
  148. data/app/views/index/index.html.erb +14 -0
  149. data/app/views/layouts/admin/_header.html.erb +7 -2
  150. data/app/views/layouts/admin.html.erb +0 -1
  151. data/app/views/layouts/application/_footer.html.erb +1 -1
  152. data/app/views/layouts/application/header/_authentication.html.erb +4 -1
  153. data/app/views/my/components/index.html.erb +25 -0
  154. data/app/views/my/components/show.html.erb +21 -0
  155. data/app/views/my/index/_cards.html.erb +15 -0
  156. data/app/views/my/index/_email.html.erb +14 -0
  157. data/app/views/my/index/_navigation.html.erb +33 -0
  158. data/app/views/my/index/index.html.erb +7 -26
  159. data/app/views/my/profiles/show.html.erb +13 -0
  160. data/app/views/{admin/components/links/extra/_content.html.erb → my/recoveries/show.html.erb} +0 -0
  161. data/app/views/shared/admin/_list.html.erb +10 -19
  162. data/app/views/shared/admin/_list_with_priority.html.erb +10 -19
  163. data/app/views/shared/admin/_priority.html.erb +6 -5
  164. data/app/views/shared/admin/_toggle.html.erb +5 -10
  165. data/app/views/shared/entity/_date_field.html.erb +6 -0
  166. data/app/views/shared/entity/_linked_entity.html.erb +2 -2
  167. data/app/views/shared/entity/_list.html.erb +22 -0
  168. data/app/views/shared/entity/_list_with_priority.html.erb +22 -0
  169. data/app/views/shared/entity/_parent.html.erb +1 -1
  170. data/app/views/shared/entity/_priority_icons.html.erb +8 -0
  171. data/app/views/shared/entity/_time_field.html.erb +6 -0
  172. data/app/views/shared/entity/_toggle.html.erb +12 -0
  173. data/app/views/shared/entity/_track.html.erb +12 -0
  174. data/app/views/shared/entity/_tree_caches.html.erb +8 -1
  175. data/app/views/shared/entity/edit.html.erb +10 -6
  176. data/app/views/shared/entity/new.html.erb +4 -2
  177. data/app/views/shared/forms/_field.html.erb +6 -2
  178. data/app/views/shared/forms/_field_with_search.html.erb +17 -0
  179. data/app/views/shared/forms/_meta_texts.html.erb +1 -1
  180. data/app/views/shared/forms/_simple_entity_link.html.erb +14 -0
  181. data/app/views/shared/forms/_simple_image.html.erb +12 -4
  182. data/app/views/shared/forms/_text_area.html.erb +1 -1
  183. data/app/views/shared/forms/_text_field.html.erb +1 -1
  184. data/app/views/shared/my/_list.html.erb +10 -19
  185. data/app/views/shared/my/_list_with_priority.html.erb +10 -19
  186. data/app/views/shared/my/entity/edit.html.erb +25 -0
  187. data/app/views/shared/my/entity/new.html.erb +18 -0
  188. data/app/views/simple_images/_simple_image.jbuilder +13 -0
  189. data/config/locales/biovision-ru.yml +18 -1
  190. data/config/locales/components-ru.yml +27 -4
  191. data/config/locales/contact-ru.yml +4 -0
  192. data/config/locales/content-ru.yml +12 -0
  193. data/config/locales/users-ru.yml +31 -6
  194. data/config/routes.rb +35 -4
  195. data/db/migrate/20191228000000_create_biovision_components.rb +2 -0
  196. data/db/migrate/20200224000000_create_track_component.rb +8 -12
  197. data/db/migrate/20200224000010_create_users_component.rb +8 -49
  198. data/db/migrate/20200404000000_create_simple_images.rb +1 -0
  199. data/db/migrate/20210405000000_create_acl.rb +15 -1
  200. data/db/migrate/{20200529000000_create_content_component.rb → 20210421000000_create_content_component.rb} +24 -18
  201. data/db/migrate/{20210401000000_create_contact_component.rb → 20210421000010_create_contact_component.rb} +1 -22
  202. data/db/migrate/20210616000000_create_uploaded_files.rb +52 -0
  203. data/db/migrate/amends/20210816060606_create_oembed_receivers.rb +21 -0
  204. data/db/migrate/amends/20210907070707_add_checksum_to_simple_images.rb +13 -0
  205. data/lib/biovision/base_methods.rb +8 -28
  206. data/lib/biovision/version.rb +1 -1
  207. data/lib/tasks/components.rake +51 -0
  208. metadata +90 -17
  209. data/app/lib/biovision/components/base/privilege_handler.rb +0 -79
  210. data/app/models/biovision_component_user.rb +0 -21
  211. data/app/views/admin/components/links/_content.html.erb +0 -9
  212. data/app/views/admin/components/links/_track.html.erb +0 -2
  213. data/app/views/admin/components/links/_users.html.erb +0 -4
  214. data/app/views/admin/components/privileges/_component_user.html.erb +0 -17
  215. data/app/views/admin/components/privileges/_links.html.erb +0 -17
  216. data/app/views/admin/components/privileges/_users.html.erb +0 -23
  217. data/app/views/admin/components/privileges.html.erb +0 -20
@@ -13,29 +13,47 @@
13
13
  <% end %>
14
14
 
15
15
  <nav class="entity-actions">
16
- <%= edit_icon(@entity) %>
16
+ <%= edit_icon(@entity) if component_handler.permit?('edit', @entity) %>
17
17
  <%= world_icon(@entity) %>
18
- <%= destroy_icon(@entity) %>
18
+ <%= destroy_icon(@entity) if component_handler.permit?('edit', @entity) %>
19
+ </nav>
20
+
21
+ <nav>
22
+ <% if current_user.super_user? %>
23
+ <%=
24
+ link_to(
25
+ "#{t('admin.users.roles.nav_text')} (#{@entity.role_ids.count})",
26
+ roles_admin_user_path,
27
+ class: 'button button-ghost'
28
+ )
29
+ %>
30
+ <% end %>
31
+ <% if component_handler.permit?('log_in', @entity) && @entity != current_user && !@entity.super_user? %>
32
+ <%=
33
+ link_to(
34
+ t('admin.users.authenticate.nav_text'),
35
+ authenticate_admin_user_path(id: @entity.id),
36
+ method: :post,
37
+ class: 'button button-secondary'
38
+ )
39
+ %>
40
+ <% end %>
19
41
  </nav>
20
42
 
21
43
  <%= render partial: 'admin/users/entity/fields', locals: { entity: @entity } %>
22
44
 
23
- <%=
24
- render(
25
- partial: 'shared/admin/toggle',
26
- locals: { entity: @entity }
27
- )
28
- %>
45
+ <%= entity_toggle(@entity) %>
29
46
 
30
47
  <% prefix = 'admin/users/entity/components/' %>
31
48
  <% BiovisionComponent.list_for_administration.each do |component| %>
32
49
  <% if lookup_context.exists?("#{prefix}_#{component.slug}") %>
50
+ <% handler = Biovision::Components::BaseComponent.handler(component, @entity) %>
33
51
  <section>
34
- <h2><%= component.name %></h2>
52
+ <h2><%= handler.name %></h2>
35
53
  <%=
36
54
  render(
37
55
  partial: "#{prefix}#{component.slug}",
38
- locals: { user: @entity }
56
+ locals: { user: @entity, handler: handler }
39
57
  )
40
58
  %>
41
59
  </section>
@@ -0,0 +1,20 @@
1
+ <%= form_with(scope: 'filter', url: url_for, method: :get, class: 'widgets__filters') do |f| %>
2
+ <fieldset>
3
+ <legend><%= t('.heading') %></legend>
4
+ <div class="list">
5
+ <% fields.each do |key, type| %>
6
+ <% if lookup_context.exists?("admin/widgets/filters/_#{type}") %>
7
+ <%=
8
+ render(
9
+ partial: "admin/widgets/filters/#{type}",
10
+ locals: { f: f, key: key, scope: scope, value: filter[key] }
11
+ )
12
+ %>
13
+ <% end %>
14
+ <% end %>
15
+ </div>
16
+ <div class="actions">
17
+ <%= button_tag(t('.apply'), class: 'button button-secondary', name: nil) %>
18
+ </div>
19
+ </fieldset>
20
+ <% end %>
@@ -0,0 +1,13 @@
1
+ <section class="widgets__quick-search js-quick-search" data-url="<%= local_assigns[:endpoint] %>">
2
+ <div class="content-wrapper">
3
+ <h3><%= t('.heading') %></h3>
4
+
5
+ <div class="search">
6
+ <label class="floating-label">
7
+ <input type="search" class="input-text" placeholder="<%= t('.search_string') %>"/>
8
+ <span><%= t('.search_string') %></span>
9
+ </label>
10
+ </div>
11
+ <ul class="results list-of-entities"></ul>
12
+ </div>
13
+ </section>
@@ -0,0 +1,15 @@
1
+ <div class="flag">
2
+ <dfn><%= t("filters.#{scope}.#{key}", default: key.to_s) %></dfn>
3
+ <label class="flag-label">
4
+ <%= f.radio_button(key, '', id: nil, checked: value.blank?) %>
5
+ <span><%= t('.any') %></span>
6
+ </label>
7
+ <label class="flag-label">
8
+ <%= f.radio_button(key, '1', id: nil, checked: value == '1') %>
9
+ <span><%= t('.set') %></span>
10
+ </label>
11
+ <label class="flag-label">
12
+ <%= f.radio_button(key, '0', id: nil, checked: value == '0') %>
13
+ <span><%= t('.unset') %></span>
14
+ </label>
15
+ </div>
@@ -0,0 +1,7 @@
1
+ <% placeholder = t("filters.#{scope}.#{key}", default: key.to_s) %>
2
+ <div class="text">
3
+ <label class="floating-label">
4
+ <%= f.text_field(key, value: value, class: 'input-text', placeholder: placeholder) %>
5
+ <span><%= placeholder %></span>
6
+ </label>
7
+ </div>
@@ -9,7 +9,10 @@
9
9
  <%=
10
10
  render(
11
11
  partial: 'components/users/form_tabs',
12
- locals: { current: 'login' }
12
+ locals: {
13
+ current: 'login',
14
+ from: url_for
15
+ }
13
16
  )
14
17
  %>
15
18
  </div>
@@ -6,16 +6,12 @@
6
6
 
7
7
  <article>
8
8
  <div class="content-wrapper">
9
- <h1><%= entity.meta('heading') %></h1>
10
-
11
- <% if content_component.editable?(entity) %>
12
- <nav class="entity-actions">
13
- <%= gear_icon(entity) %>
14
- <%= edit_icon(entity) %>
15
- </nav>
16
- <% end %>
17
-
18
- <div class="text"><%= raw(entity.body) %></div>
9
+ <%=
10
+ render(
11
+ partial: 'components/content/dynamic_page_content',
12
+ locals: { entity: entity }
13
+ )
14
+ %>
19
15
  </div>
20
16
  </article>
21
17
  <% end %>
@@ -0,0 +1,14 @@
1
+ <% unless entity.simple_image.nil? %>
2
+ <figure><%= simple_image_hd(entity) %></figure>
3
+ <% end %>
4
+
5
+ <h1><%= entity.meta('heading') %></h1>
6
+
7
+ <% if content_component.permit?('edit', entity) %>
8
+ <nav class="entity-actions">
9
+ <%= gear_icon(entity) %>
10
+ <%= edit_icon(entity) %>
11
+ </nav>
12
+ <% end %>
13
+
14
+ <div class="text"><%= raw(entity.body) %></div>
@@ -33,6 +33,7 @@
33
33
  </div>
34
34
  </div>
35
35
  <div class="actions">
36
+ <%= hidden_field_tag(:from, local_assigns[:from], id: nil) %>
36
37
  <%= button_tag t('.log_in'), class: 'button button-primary', name: nil %>
37
38
  <%=
38
39
  link_to(
@@ -100,7 +100,7 @@
100
100
  <%= button_tag(t('.submit'), class: 'button button-primary') %>
101
101
  </div>
102
102
  </div>
103
- <div class="state-2">
103
+ <div class="state-2 hidden">
104
104
  <div class="result">
105
105
  <p><%= raw message %></p>
106
106
  </div>
@@ -0,0 +1 @@
1
+ <div class="message-box error"><%= @message %></div>
@@ -0,0 +1,11 @@
1
+ <h1><%= t('.title') %></h1>
2
+
3
+ <dl>
4
+ <% %w[name email phone comment attachment].each do |attribute| %>
5
+ <% next if @entity.attributes[attribute].blank? %>
6
+ <div>
7
+ <dt><%= @entity.class.human_attribute_name(attribute) %></dt>
8
+ <dd><%= @entity.attributes[attribute] %></dd>
9
+ </div>
10
+ <% end %>
11
+ </dl>
@@ -0,0 +1,6 @@
1
+ <%= t('.title') %>
2
+
3
+ <% %w[name email phone comment attachment].each do |a| %>
4
+ <% next if @entity.attributes[a].blank? %>
5
+ <%= @entity.class.human_attribute_name(a) %>: <%= @entity.attributes[a] %>
6
+ <% end %>
@@ -0,0 +1,14 @@
1
+ <%= render partial: 'shared/entity/metadata', locals: { entity: @dynamic_page } %>
2
+
3
+ <article class="frontpage">
4
+ <div class="content-wrapper">
5
+ <% unless @dynamic_page.blank? %>
6
+ <%=
7
+ render(
8
+ partial: 'components/content/dynamic_page_content',
9
+ locals: { entity: @dynamic_page }
10
+ )
11
+ %>
12
+ <% end %>
13
+ </div>
14
+ </article>
@@ -2,8 +2,13 @@
2
2
  <%= render 'layouts/admin/header/logo' %>
3
3
  <nav>
4
4
  <% unless current_user.nil? %>
5
- <ul>
6
- <li><%= current_user.screen_name %></li>
5
+ <ul class="header-authentication">
6
+ <li>
7
+ <a href="<%= my_path %>" class="current-user">
8
+ <span class="avatar"><%= simple_image_tiny(current_user) %></span>
9
+ <span><%= current_user.screen_name %></span>
10
+ </a>
11
+ </li>
7
12
  <li>
8
13
  <%=
9
14
  link_to(
@@ -10,7 +10,6 @@
10
10
  </head>
11
11
  <body>
12
12
  <%= render 'layouts/admin/header' %>
13
- <%= controller_name %>/<%= action_name %>
14
13
  <main id="main">
15
14
  <%= render 'shared/flash_messages' %>
16
15
  <%= render 'layouts/admin/breadcrumbs' %>
@@ -1,7 +1,7 @@
1
1
  <footer class="main-footer">
2
2
  <div class="content-wrapper">
3
3
  <div class="copyright">&copy; <%= t(:copyright) %></div>
4
- <% if Biovision::Components::BaseComponent.privileged?(current_user) %>
4
+ <% if current_user&.role?('base.admin') %>
5
5
  <%= link_to(t('admin.index.index.nav_text'), admin_path) %>
6
6
  <% end %>
7
7
  </div>
@@ -2,7 +2,10 @@
2
2
  <% if current_user.nil? %>
3
3
  <%= link_to(image_tag('biovision/icons/log_in.svg', alt: t(:log_in)), login_path) %>
4
4
  <% else %>
5
- <%= link_to(simple_image_tiny(current_user), my_path, class: 'avatar') %>
5
+ <a href="<%= my_path %>" class="current-user">
6
+ <span class="avatar"><%= simple_image_tiny(current_user) %></span>
7
+ <span><%= current_user.screen_name %></span>
8
+ </a>
6
9
  <%=
7
10
  link_to(
8
11
  image_tag('biovision/icons/log_out.svg', alt: t(:log_out)),
@@ -0,0 +1,25 @@
1
+ <% content_for :meta_title, t('.title') %>
2
+ <% content_for :breadcrumbs do %>
3
+ <%= my_home_link %>
4
+ <span><%= t('.nav_text') %></span>
5
+ <% end %>
6
+
7
+ <article>
8
+ <div class="content-wrapper">
9
+ <h1><%= t('.heading') %></h1>
10
+ </div>
11
+
12
+ <% prefix = 'my/components/' %>
13
+ <% @collection.each do |component| %>
14
+ <% handler = Biovision::Components::BaseComponent.handler(component, current_user) %>
15
+ <% next unless handler&.permit?('default') %>
16
+ <% if lookup_context.exists?("#{prefix}#{component.slug}/_dashboard") %>
17
+ <%=
18
+ render(
19
+ partial: "#{prefix}#{component.slug}/dashboard",
20
+ locals: { handler: handler }
21
+ )
22
+ %>
23
+ <% end %>
24
+ <% end %>
25
+ </article>
@@ -0,0 +1,21 @@
1
+ <% content_for :meta_title, t('.title', component: @handler.name) %>
2
+ <% content_for :breadcrumbs do %>
3
+ <%= link_to(t('my.components.index.nav_text'), my_dashboard_path) %>
4
+ <span><%= @handler.name %></span>
5
+ <% end %>
6
+
7
+ <% prefix = "my/components/#{@handler.slug}/" %>
8
+ <% if lookup_context.exists?("#{prefix}_section") %>
9
+ <%=
10
+ render(
11
+ partial: "#{prefix}#{component.slug}",
12
+ locals: { handler: @handler }
13
+ )
14
+ %>
15
+ <% else %>
16
+ <article class="content-wrapper">
17
+ <h1><%= @handler.name %></h1>
18
+
19
+ <div class="message-box warning"><%= t('.no_view') %></div>
20
+ </article>
21
+ <% end %>
@@ -0,0 +1,15 @@
1
+ <section class="my__component-cards">
2
+ <% prefix = 'my/components/' %>
3
+ <% BiovisionComponent.list_for_user.each do |component| %>
4
+ <% handler = Biovision::Components::BaseComponent.handler(component, current_user) %>
5
+ <% next unless handler&.permit?('default') %>
6
+ <% if lookup_context.exists?("#{prefix}_#{component.slug}") %>
7
+ <%=
8
+ render(
9
+ partial: "#{prefix}#{component.slug}",
10
+ locals: { user: @entity, handler: handler }
11
+ )
12
+ %>
13
+ <% end %>
14
+ <% end %>
15
+ </section>
@@ -0,0 +1,14 @@
1
+ <% if handler.needs_email_confirmation? %>
2
+ <div class="message-box warning">
3
+ <p><%= t('.email_is_not_confirmed') %></p>
4
+ <p>
5
+ <%=
6
+ link_to(
7
+ t('my.confirmations.show.nav_text'),
8
+ my_confirmation_path,
9
+ class: 'button button-secondary'
10
+ )
11
+ %>
12
+ </p>
13
+ </div>
14
+ <% end %>
@@ -0,0 +1,33 @@
1
+ <nav>
2
+ <%=
3
+ link_to(
4
+ t('my.profiles.show.nav_text'),
5
+ my_profile_path,
6
+ class: 'button button-ghost'
7
+ )
8
+ %>
9
+ <%=
10
+ link_to(
11
+ t('my.components.index.nav_text'),
12
+ my_dashboard_path,
13
+ class: 'button button-ghost'
14
+ )
15
+ %>
16
+ <% if current_user.role?('base.admin') %>
17
+ <%=
18
+ link_to(
19
+ t('admin.index.index.nav_text'),
20
+ admin_path,
21
+ class: 'button button-secondary'
22
+ )
23
+ %>
24
+ <% end %>
25
+ <%=
26
+ link_to(
27
+ t(:log_out),
28
+ logout_path,
29
+ class: 'button button-secondary',
30
+ method: :delete
31
+ )
32
+ %>
33
+ </nav>
@@ -3,31 +3,12 @@
3
3
  <span><%= t('.nav_text') %></span>
4
4
  <% end %>
5
5
 
6
- <article class="content-wrapper">
7
- <h1><%= t('.heading') %></h1>
6
+ <article>
7
+ <div class="content-wrapper">
8
+ <h1><%= t('.heading') %></h1>
8
9
 
9
- <% if component_handler.needs_email_confirmation? %>
10
- <div class="message-box warning">
11
- <p><%= t('.email_is_not_confirmed') %></p>
12
- <p>
13
- <%=
14
- link_to(
15
- t('my.confirmations.show.nav_text'),
16
- my_confirmation_path,
17
- class: 'button button-secondary'
18
- )
19
- %>
20
- </p>
21
- </div>
22
- <% end %>
23
-
24
- <nav>
25
- <%=
26
- link_to(
27
- t('my.profiles.show.nav_text'),
28
- my_profile_path,
29
- class: 'button button-ghost'
30
- )
31
- %>
32
- </nav>
10
+ <%= render partial: 'my/index/email', locals: { handler: component_handler } %>
11
+ <%= render 'my/index/navigation' %>
12
+ <%= render 'my/index/cards' %>
13
+ </div>
33
14
  </article>
@@ -19,5 +19,18 @@
19
19
  </nav>
20
20
 
21
21
  <%= render partial: 'users/profile', locals: { user: current_user } %>
22
+
23
+ <% prefix = 'my/profiles/components/' %>
24
+ <% BiovisionComponent.list_for_user.each do |component| %>
25
+ <% handler = Biovision::Components::BaseComponent.handler(component, current_user) %>
26
+ <% if lookup_context.exists?("#{prefix}_#{component.slug}") %>
27
+ <%=
28
+ render(
29
+ partial: "#{prefix}#{component.slug}",
30
+ locals: { handler: handler }
31
+ )
32
+ %>
33
+ <% end %>
34
+ <% end %>
22
35
  </div>
23
36
  </article>
@@ -1,19 +1,10 @@
1
- <% use_pagination = collection.respond_to?(:current_page) %>
2
- <%= paginate collection if use_pagination %>
3
- <% if collection.any? %>
4
- <ul class="list-of-entities">
5
- <% collection.each do |entity| %>
6
- <li data-id="<%= entity.id %>">
7
- <%=
8
- render(
9
- partial: "admin/#{entity.class.table_name}/entity/in_list",
10
- locals: { entity: entity, handler: local_assigns[:handler] }
11
- )
12
- %>
13
- </li>
14
- <% end %>
15
- </ul>
16
- <%= paginate collection if use_pagination %>
17
- <% else %>
18
- <%= render 'shared/nothing_found' %>
19
- <% end %>
1
+ <%=
2
+ render(
3
+ partial: 'shared/entity/list',
4
+ locals: {
5
+ collection: collection,
6
+ handler: local_assigns[:handler],
7
+ scope: :admin
8
+ }
9
+ )
10
+ %>
@@ -1,19 +1,10 @@
1
- <% use_pagination = collection.respond_to?(:current_page) %>
2
- <%= paginate collection if use_pagination %>
3
- <% if collection.any? %>
4
- <ol class="list-of-entities">
5
- <% collection.each do |entity| %>
6
- <li data-id="<%= entity.id %>" data-number="<%= entity.priority %>">
7
- <%=
8
- render(
9
- partial: "admin/#{entity.class.table_name}/entity/in_list",
10
- locals: { entity: entity, handler: local_assigns[:handler] }
11
- )
12
- %>
13
- </li>
14
- <% end %>
15
- </ol>
16
- <%= paginate collection if use_pagination %>
17
- <% else %>
18
- <%= render 'shared/nothing_found' %>
19
- <% end %>
1
+ <%=
2
+ render(
3
+ partial: 'shared/entity/list_with_priority',
4
+ locals: {
5
+ collection: collection,
6
+ handler: local_assigns[:handler],
7
+ scope: :admin
8
+ }
9
+ )
10
+ %>
@@ -1,5 +1,6 @@
1
- <% url = "/admin/#{entity.class.table_name}/#{entity.id}/priority" %>
2
- <div class="priority-changer" data-url="<%= url %>">
3
- <button data-delta="-1" type="button">&uarr;</button>
4
- <button data-delta="1" type="button">&darr;</button>
5
- </div>
1
+ <%=
2
+ render(
3
+ partial: 'shared/entity/priority_icons',
4
+ locals: { entity: entity, scope: :admin }
5
+ )
6
+ %>
@@ -1,11 +1,6 @@
1
- <%
2
- model = entity.class
3
- url = "/admin/#{model.table_name}/#{entity.id}/toggle"
1
+ <%=
2
+ render(
3
+ partial: 'shared/entity/toggle',
4
+ locals: { entity: entity, scope: :admin }
5
+ )
4
6
  %>
5
- <div class="toggleable" data-url="<%= url %>">
6
- <% model.toggleable_attributes.each do |flag| %>
7
- <span class="<%= entity.attributes[flag.to_s] ? 'active' : 'inactive' %>" data-flag="<%= flag %>">
8
- <%= model.human_attribute_name(flag) %>
9
- </span>
10
- <% end %>
11
- </div>
@@ -0,0 +1,6 @@
1
+ <% unless entity.attributes[field.to_s].blank? %>
2
+ <div>
3
+ <dt><%= entity.class.human_attribute_name(field) %></dt>
4
+ <dd><%= time_tag(entity.attributes[field.to_s]) %></dd>
5
+ </div>
6
+ <% end %>
@@ -1,6 +1,6 @@
1
1
  <% unless entity.nil? %>
2
2
  <div>
3
- <dt><%= entity.class.model_name.human %></dt>
4
- <dd><%= admin_entity_link(entity) %></dd>
3
+ <dt><%= local_assigns[:text] || entity.class.model_name.human %></dt>
4
+ <dd><%= admin_entity_link(entity, handler: local_assigns[:handler]) %></dd>
5
5
  </div>
6
6
  <% end %>
@@ -0,0 +1,22 @@
1
+ <%
2
+ view_scope = %i[admin my].include?(local_assigns[:scope].to_sym) ? "#{scope}/" : ''
3
+ use_pagination = collection.respond_to?(:current_page)
4
+ %>
5
+ <%= paginate collection if use_pagination %>
6
+ <% if collection.any? %>
7
+ <ul class="list-of-entities">
8
+ <% collection.each do |entity| %>
9
+ <li data-id="<%= entity.id %>">
10
+ <%=
11
+ render(
12
+ partial: "#{view_scope}#{entity.class.table_name}/entity/in_list",
13
+ locals: { entity: entity, handler: local_assigns[:handler] }
14
+ )
15
+ %>
16
+ </li>
17
+ <% end %>
18
+ </ul>
19
+ <%= paginate collection if use_pagination %>
20
+ <% else %>
21
+ <%= render 'shared/nothing_found' %>
22
+ <% end %>
@@ -0,0 +1,22 @@
1
+ <%
2
+ view_scope = %i[admin my].include?(local_assigns[:scope].to_sym) ? "#{scope}/" : ''
3
+ use_pagination = collection.respond_to?(:current_page)
4
+ %>
5
+ <%= paginate collection if use_pagination %>
6
+ <% if collection.any? %>
7
+ <ol class="list-of-entities">
8
+ <% collection.each do |entity| %>
9
+ <li data-id="<%= entity.id %>" data-number="<%= entity.priority %>">
10
+ <%=
11
+ render(
12
+ partial: "#{view_scope}#{entity.class.table_name}/entity/in_list",
13
+ locals: { entity: entity, handler: local_assigns[:handler] }
14
+ )
15
+ %>
16
+ </li>
17
+ <% end %>
18
+ </ol>
19
+ <%= paginate collection if use_pagination %>
20
+ <% else %>
21
+ <%= render 'shared/nothing_found' %>
22
+ <% end %>
@@ -1,6 +1,6 @@
1
1
  <% unless entity.parent.blank? %>
2
2
  <div>
3
3
  <dt><%= entity.class.human_attribute_name(:parent) %></dt>
4
- <dd><%= admin_entity_link(entity.parent) %></dd>
4
+ <dd><%= admin_entity_link(entity.parent, handler: local_assigns[:handler]) %></dd>
5
5
  </div>
6
6
  <% end %>
@@ -0,0 +1,8 @@
1
+ <%
2
+ view_scope = %i[admin my].include?(local_assigns[:scope].to_sym) ? "#{scope}/" : ''
3
+ url = "/#{view_scope}#{entity.class.table_name}/#{entity.id}/priority"
4
+ %>
5
+ <div class="priority-changer" data-url="<%= url %>">
6
+ <button data-delta="-1" type="button">&uarr;</button>
7
+ <button data-delta="1" type="button">&darr;</button>
8
+ </div>
@@ -0,0 +1,6 @@
1
+ <% unless entity.attributes[field.to_s].nil? %>
2
+ <div>
3
+ <dt><%= entity.class.human_attribute_name(field) %></dt>
4
+ <dd><%= time_tag entity.attributes[field.to_s] %></dd>
5
+ </div>
6
+ <% end %>