sufia 4.0.0.beta2 → 4.0.0.beta3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (335) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +3 -0
  3. data/README.md +6 -4
  4. data/SUFIA_VERSION +1 -1
  5. data/app/assets/images/folder.png +0 -0
  6. data/app/assets/javascripts/sufia.js +5 -0
  7. data/app/assets/javascripts/sufia/app.js +1 -0
  8. data/app/assets/javascripts/sufia/batch_select_all.js +1 -2
  9. data/app/assets/javascripts/sufia/dashboard_actions.js +13 -0
  10. data/app/assets/javascripts/sufia/editor.js +1 -1
  11. data/app/assets/javascripts/sufia/ga_events.js +10 -0
  12. data/app/assets/javascripts/sufia/search.js +67 -0
  13. data/app/assets/stylesheets/dashboard.css.scss +15 -1
  14. data/app/assets/stylesheets/sufia.css.scss +12 -0
  15. data/app/controllers/authorities_controller.rb +4 -4
  16. data/app/controllers/batch_controller.rb +4 -4
  17. data/app/controllers/collections_controller.rb +44 -0
  18. data/{lib → app/controllers/concerns}/sufia/batch_edits_controller_behavior.rb +1 -1
  19. data/app/controllers/concerns/sufia/catalog.rb +9 -45
  20. data/{lib → app/controllers/concerns}/sufia/controller.rb +11 -21
  21. data/app/controllers/concerns/sufia/dashboard_controller_behavior.rb +34 -6
  22. data/{lib → app/controllers/concerns}/sufia/downloads_controller_behavior.rb +0 -0
  23. data/app/controllers/concerns/sufia/files_controller/browse_everything.rb +35 -0
  24. data/{lib → app/controllers/concerns}/sufia/files_controller/local_ingest_behavior.rb +19 -7
  25. data/{lib → app/controllers/concerns}/sufia/files_controller/upload_complete_behavior.rb +1 -1
  26. data/app/controllers/concerns/sufia/files_controller_behavior.rb +219 -0
  27. data/app/controllers/concerns/sufia/homepage_controller.rb +41 -0
  28. data/app/controllers/concerns/sufia/users_controller_behavior.rb +3 -2
  29. data/app/controllers/dashboard/collections_controller.rb +19 -0
  30. data/app/controllers/dashboard/files_controller.rb +13 -0
  31. data/app/controllers/dashboard/highlights_controller.rb +20 -0
  32. data/app/controllers/dashboard/lists_controller.rb +13 -0
  33. data/app/controllers/dashboard/shares_controller.rb +19 -0
  34. data/app/controllers/directory_controller.rb +8 -8
  35. data/app/controllers/featured_work_lists_controller.rb +1 -1
  36. data/app/controllers/homepage_controller.rb +4 -0
  37. data/app/controllers/single_use_links_controller.rb +6 -6
  38. data/app/controllers/single_use_links_viewer_controller.rb +6 -6
  39. data/app/controllers/static_controller.rb +4 -3
  40. data/app/helpers/batch_edits_helper.rb +3 -6
  41. data/app/helpers/content_block_helper.rb +7 -2
  42. data/app/helpers/generic_file_helper.rb +33 -39
  43. data/app/helpers/records_helper.rb +4 -0
  44. data/app/helpers/sufia/blacklight_override.rb +11 -0
  45. data/app/helpers/sufia/records_helper_behavior.rb +38 -0
  46. data/app/helpers/sufia/sufia_helper_behavior.rb +109 -0
  47. data/{sufia-models/lib/sufia/models → app/models/concerns/sufia}/solr_document_behavior.rb +6 -1
  48. data/app/models/contact_form.rb +13 -13
  49. data/app/uploaders/tinymce_asset_uploader.rb +2 -2
  50. data/app/views/_controls.html.erb +1 -1
  51. data/app/views/_flash_msg.html.erb +2 -8
  52. data/app/views/_ga.html.erb +4 -0
  53. data/app/views/_user_util_links.html.erb +7 -7
  54. data/app/views/advanced/_advanced_search_facets.html.erb +1 -1
  55. data/app/views/advanced/_advanced_search_fields.html.erb +2 -2
  56. data/app/views/advanced/_advanced_search_form.html.erb +12 -12
  57. data/app/views/batch/_metadata.html.erb +12 -12
  58. data/app/views/batch/_more_metadata.html.erb +1 -2
  59. data/app/views/batch/edit.html.erb +5 -5
  60. data/app/views/batch_edits/_check_all.html.erb +1 -1
  61. data/app/views/batch_edits/_delete_selected.html.erb +2 -3
  62. data/app/views/batch_edits/edit.html.erb +20 -21
  63. data/app/views/catalog/_bookmark_control.html.erb +7 -8
  64. data/app/views/catalog/_constraints_element.html.erb +2 -2
  65. data/app/views/catalog/_delete_partials/_default.html.erb +9 -12
  66. data/app/views/catalog/_document.html.erb +5 -5
  67. data/app/views/catalog/_document_list.html.erb +2 -2
  68. data/app/views/catalog/_edit_partials/_default.html.erb +6 -9
  69. data/app/views/catalog/_edit_partials/_default_details.html.erb +2 -4
  70. data/app/views/catalog/_email_form.html.erb +1 -1
  71. data/app/views/catalog/_facet_limit.html.erb +6 -7
  72. data/app/views/catalog/_facet_selected.html.erb +3 -3
  73. data/app/views/catalog/_folder_control.html.erb +7 -8
  74. data/app/views/catalog/_index_default.html.erb +2 -2
  75. data/app/views/catalog/_index_header_default.html.erb +20 -0
  76. data/app/views/catalog/_index_partials/_default_group.html.erb +1 -1
  77. data/app/views/catalog/_index_partials/_list_files.html.erb +5 -2
  78. data/app/views/catalog/_refworks_form.html.erb +2 -2
  79. data/app/views/catalog/_results_pagination.html.erb +1 -1
  80. data/app/views/catalog/_search_form.html.erb +24 -9
  81. data/app/views/catalog/_show_default.html.erb +2 -2
  82. data/app/views/catalog/_show_partials/_default.html.erb +4 -5
  83. data/app/views/catalog/_show_partials/_default_details.html.erb +5 -5
  84. data/app/views/catalog/_show_partials/_facets.html.erb +7 -7
  85. data/app/views/catalog/_show_tools.html.erb +6 -6
  86. data/app/views/catalog/_sms_form.html.erb +1 -1
  87. data/app/views/catalog/_sort_and_per_page.html.erb +8 -14
  88. data/app/views/catalog/citation.html.erb +1 -1
  89. data/app/views/catalog/email.erb +1 -1
  90. data/app/views/catalog/index.html.erb +16 -27
  91. data/app/views/catalog/recent.js.erb +1 -1
  92. data/app/views/catalog/show.html.erb +2 -2
  93. data/app/views/catalog/sms.erb +1 -1
  94. data/app/views/collections/_action_menu.html.erb +24 -0
  95. data/app/views/collections/_batch_edits_actions.html.erb +3 -0
  96. data/app/views/collections/_button_for_creating_empty_collection.html.erb +3 -0
  97. data/app/views/collections/_dashboard_document_list.html.erb +6 -0
  98. data/app/views/collections/_document_list.html.erb +10 -0
  99. data/app/views/collections/_edit_actions.html.erb +5 -0
  100. data/app/views/collections/_edit_descriptions.html.erb +20 -0
  101. data/app/views/collections/_form.html.erb +24 -0
  102. data/app/views/collections/_form_for_select_collection.html.erb +34 -0
  103. data/app/views/collections/_media_display.html.erb +1 -0
  104. data/app/views/collections/_paginate.html.erb +6 -0
  105. data/app/views/collections/_search_collection_dashboard_form.html.erb +10 -0
  106. data/app/views/collections/_show_actions.html.erb +7 -0
  107. data/app/views/collections/_show_descriptions.html.erb +8 -0
  108. data/app/views/collections/_show_fields.html.erb +0 -0
  109. data/app/views/collections/_single_item_action_fields.html.erb +6 -0
  110. data/app/views/collections/_sort_and_per_page.html.erb +29 -0
  111. data/app/views/collections/_view_type_group.html.erb +13 -0
  112. data/app/views/collections/edit.html.erb +30 -0
  113. data/app/views/collections/show.html.erb +32 -0
  114. data/app/views/contact_form/new.html.erb +13 -13
  115. data/app/views/dashboard/_action_menu.html.erb +29 -0
  116. data/app/views/dashboard/_collection_action_menu.html.erb +15 -0
  117. data/app/views/dashboard/_document_list.html.erb +1 -1
  118. data/app/views/dashboard/_facet_limit.html.erb +2 -2
  119. data/app/views/dashboard/_facet_pagination.html.erb +12 -12
  120. data/app/views/dashboard/_facet_selected.html.erb +2 -2
  121. data/app/views/dashboard/_facets.html.erb +2 -0
  122. data/app/views/dashboard/_index_partials/_default_group.html.erb +9 -2
  123. data/app/views/dashboard/_index_partials/_list_collections.html.erb +45 -0
  124. data/app/views/dashboard/_index_partials/_list_files.html.erb +5 -25
  125. data/app/views/dashboard/_results_pagination.html.erb +1 -1
  126. data/app/views/dashboard/_search_form.html.erb +2 -2
  127. data/app/views/dashboard/_show_partials/_default.html.erb +3 -3
  128. data/app/views/dashboard/_show_partials/_default_details.html.erb +5 -5
  129. data/app/views/dashboard/_show_partials/_facets.html.erb +6 -6
  130. data/app/views/dashboard/_sort_and_per_page.html.erb +24 -8
  131. data/app/views/dashboard/facet.html.erb +3 -3
  132. data/app/views/dashboard/index.html.erb +18 -41
  133. data/app/views/dashboard/lists/index.html.erb +59 -0
  134. data/app/views/generic_files/_breadcrumbs.html.erb +4 -4
  135. data/app/views/generic_files/_descriptions.html.erb +4 -4
  136. data/app/views/generic_files/_field_form.html.erb +5 -5
  137. data/app/views/generic_files/_flot_stats.js.erb +120 -0
  138. data/app/views/generic_files/_media_display.html.erb +14 -4
  139. data/app/views/generic_files/_permission.html.erb +3 -3
  140. data/app/views/generic_files/_permission_form.html.erb +20 -21
  141. data/app/views/generic_files/_show_actions.html.erb +13 -10
  142. data/app/views/generic_files/_show_details.html.erb +16 -9
  143. data/app/views/generic_files/_versioning.html.erb +3 -3
  144. data/app/views/generic_files/edit.html.erb +7 -7
  145. data/app/views/generic_files/edit_fields/_default.html.erb +3 -4
  146. data/app/views/generic_files/edit_fields/_description.html.erb +3 -4
  147. data/app/views/generic_files/edit_fields/_resource_type.html.erb +1 -3
  148. data/app/views/generic_files/edit_fields/_rights.html.erb +3 -5
  149. data/app/views/generic_files/edit_fields/_suffix.html.erb +1 -1
  150. data/app/views/generic_files/show.html.erb +3 -3
  151. data/app/views/generic_files/stats.html.erb +8 -124
  152. data/app/views/generic_files/upload/_alerts.html.erb +2 -4
  153. data/app/views/generic_files/upload/_form.html.erb +1 -1
  154. data/app/views/generic_files/upload/_local_file_import_chooser.html.erb +1 -1
  155. data/app/views/generic_files/upload/_tos_checkbox.html.erb +1 -1
  156. data/app/views/homepage/_featured.html.erb +3 -1
  157. data/app/views/{catalog → homepage}/_featured_researcher.html.erb +0 -0
  158. data/app/views/{catalog → homepage}/_home.html.erb +1 -0
  159. data/app/views/{catalog → homepage}/_home_content.html.erb +4 -4
  160. data/app/views/homepage/_home_header.html.erb +12 -0
  161. data/app/views/homepage/_marketing.html.erb +4 -0
  162. data/app/views/{catalog → homepage}/_recent_document.html.erb +10 -5
  163. data/app/views/homepage/_recents.html.erb +15 -0
  164. data/app/views/homepage/_sortable_featured.html.erb +3 -1
  165. data/app/views/{catalog → homepage}/_tagcloud.html.erb +0 -0
  166. data/app/views/homepage/index.html.erb +1 -0
  167. data/app/views/kaminari/blacklight/_first_page.html.erb +1 -1
  168. data/app/views/kaminari/blacklight/_last_page.html.erb +1 -1
  169. data/app/views/kaminari/blacklight/_next_page.html.erb +1 -1
  170. data/app/views/kaminari/blacklight/_page.html.erb +1 -1
  171. data/app/views/kaminari/blacklight/_prev_page.html.erb +1 -1
  172. data/app/views/layouts/_head_tag_content.html.erb +1 -1
  173. data/app/views/layouts/error.html.erb +2 -2
  174. data/app/views/layouts/homepage.html.erb +4 -4
  175. data/app/views/layouts/sufia-dashboard.html.erb +7 -7
  176. data/app/views/layouts/sufia-one-column.html.erb +4 -4
  177. data/app/views/layouts/sufia-two-column.html.erb +7 -7
  178. data/app/views/mailbox/index.html.erb +2 -2
  179. data/app/views/pages/show.html.erb +1 -0
  180. data/app/views/records/_edit_field.html.erb +18 -0
  181. data/app/views/records/edit_fields/_description.html.erb +10 -0
  182. data/app/views/records/edit_fields/_resource_type.html.erb +7 -0
  183. data/app/views/records/edit_fields/_rights.html.erb +6 -0
  184. data/app/views/records/edit_fields/_suffix.html.erb +9 -0
  185. data/app/views/records/edit_fields/_type.html.erb +13 -0
  186. data/app/views/single_use_links/new_download.html.erb +1 -1
  187. data/app/views/users/_activity.html.erb +1 -1
  188. data/app/views/users/_contributions.html.erb +3 -1
  189. data/app/views/users/_left_sidebar.html.erb +1 -1
  190. data/app/views/users/_notify_link.html.erb +2 -2
  191. data/app/views/users/_profile.html.erb +2 -2
  192. data/app/views/users/_search_form.html.erb +3 -3
  193. data/app/views/users/edit.html.erb +15 -15
  194. data/app/views/users/index.html.erb +3 -3
  195. data/app/views/users/notifications_number.js.erb +1 -1
  196. data/config/locales/sufia.en.yml +13 -2
  197. data/config/routes.rb +56 -20
  198. data/db/seeds.rb +2 -2
  199. data/lib/generators/sufia/sufia_generator.rb +14 -4
  200. data/lib/generators/sufia/templates/catalog_controller.rb +98 -97
  201. data/lib/generators/sufia/templates/sufia_helper.rb +5 -0
  202. data/lib/sufia.rb +4 -0
  203. data/spec/{models/generic_file/actions_spec.rb → actors/generic_file/actor_spec.rb} +2 -2
  204. data/spec/controllers/authorities_controller_spec.rb +7 -7
  205. data/spec/controllers/batch_controller_spec.rb +22 -23
  206. data/spec/controllers/batch_edits_controller_spec.rb +4 -4
  207. data/spec/controllers/catalog_controller_spec.rb +27 -37
  208. data/spec/controllers/collections_controller_spec.rb +179 -0
  209. data/spec/controllers/dashboard/collections_controller_spec.rb +71 -0
  210. data/spec/controllers/dashboard/files_controller_spec.rb +71 -0
  211. data/spec/controllers/dashboard/highlights_controller_spec.rb +66 -0
  212. data/spec/controllers/dashboard/shares_controller_spec.rb +78 -0
  213. data/spec/controllers/dashboard_controller_spec.rb +0 -47
  214. data/spec/controllers/downloads_controller_spec.rb +10 -11
  215. data/spec/controllers/generic_files_controller_spec.rb +147 -118
  216. data/spec/controllers/homepage_controller_spec.rb +57 -0
  217. data/spec/controllers/mailbox_controller_spec.rb +3 -3
  218. data/spec/controllers/single_use_links_viewer_controller_spec.rb +3 -3
  219. data/spec/factories/generic_files.rb +4 -0
  220. data/spec/factories/users.rb +0 -1
  221. data/spec/features/browse_dashboard_files_spec.rb +5 -1
  222. data/spec/features/collection_spec.rb +232 -0
  223. data/spec/features/display_dashboard_spec.rb +1 -0
  224. data/spec/features/notifications_spec.rb +1 -1
  225. data/spec/features/search_spec.rb +22 -0
  226. data/spec/features/single_use_links_spec.rb +2 -2
  227. data/spec/features/users_spec.rb +1 -1
  228. data/spec/fixtures/charter.docx +0 -0
  229. data/spec/helpers/records_helper_spec.rb +61 -0
  230. data/spec/helpers/sufia_helper_spec.rb +40 -2
  231. data/spec/{models → jobs}/active_fedora_pid_based_job_spec.rb +0 -0
  232. data/spec/{models → jobs}/audit_job_spec.rb +0 -2
  233. data/spec/{models → jobs}/batch_update_job_spec.rb +2 -2
  234. data/spec/jobs/characterize_job_spec.rb +25 -0
  235. data/spec/jobs/create_derivatives_job_spec.rb +186 -0
  236. data/spec/{models → jobs}/event_jobs_spec.rb +0 -1
  237. data/spec/jobs/import_url_job_spec.rb +36 -14
  238. data/spec/jobs/ingest_local_file_job_spec.rb +2 -2
  239. data/spec/lib/sufia/analytics_spec.rb +29 -0
  240. data/spec/lib/sufia/upload_complete_behavior_spec.rb +1 -1
  241. data/spec/models/batch_spec.rb +3 -9
  242. data/spec/models/checksum_audit_log_spec.rb +5 -6
  243. data/spec/models/collection_spec.rb +24 -0
  244. data/spec/models/download_spec.rb +21 -0
  245. data/spec/models/featured_work_list_spec.rb +0 -1
  246. data/spec/models/file_content_datastream_spec.rb +8 -14
  247. data/spec/models/file_usage_spec.rb +91 -0
  248. data/spec/models/fits_datastream_spec.rb +1 -1
  249. data/spec/models/generic_file/web_form_spec.rb +2 -2
  250. data/spec/models/generic_file_rdf_datastream_spec.rb +12 -0
  251. data/spec/models/generic_file_spec.rb +150 -168
  252. data/spec/models/local_authority_spec.rb +9 -9
  253. data/spec/models/{pageview.rb → pageview_spec.rb} +0 -0
  254. data/spec/models/single_use_link_spec.rb +32 -35
  255. data/spec/routing/route_spec.rb +19 -3
  256. data/spec/spec_helper.rb +28 -6
  257. data/spec/support/features/session_helpers.rb +5 -6
  258. data/spec/support/lib/generators/test_app_generator.rb +6 -0
  259. data/spec/views/generic_file/edit.html.erb_spec.rb +4 -4
  260. data/spec/views/generic_file/show.html.erb_spec.rb +45 -17
  261. data/spec/views/generic_file/stats.html.erb_spec.rb +26 -7
  262. data/sufia-models/app/actors/sufia/generic_file/actor.rb +98 -0
  263. data/sufia-models/app/models/batch.rb +3 -3
  264. data/sufia-models/app/models/checksum_audit_log.rb +3 -3
  265. data/sufia-models/app/models/collection.rb +41 -0
  266. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file.rb +33 -43
  267. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file/accessible_attributes.rb +3 -3
  268. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file/audit.rb +12 -18
  269. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file/characterization.rb +1 -8
  270. data/sufia-models/app/models/concerns/sufia/generic_file/derivatives.rb +26 -0
  271. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file/export.rb +13 -13
  272. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file/featured.rb +0 -0
  273. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file/metadata.rb +0 -0
  274. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file/mime_types.rb +15 -1
  275. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file/permissions.rb +5 -1
  276. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file/reload_on_save.rb +0 -0
  277. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file/trophies.rb +0 -0
  278. data/sufia-models/app/models/concerns/sufia/generic_file/versions.rb +16 -0
  279. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file/virus_check.rb +2 -3
  280. data/sufia-models/{lib/sufia/models → app/models/concerns/sufia}/generic_file/web_form.rb +9 -2
  281. data/sufia-models/app/models/concerns/sufia/properties_datastream_behavior.rb +3 -4
  282. data/sufia-models/app/models/concerns/sufia/user.rb +2 -2
  283. data/sufia-models/app/models/datastreams/fits_datastream.rb +137 -136
  284. data/sufia-models/app/models/datastreams/generic_file_rdf_datastream.rb +6 -0
  285. data/sufia-models/app/models/datastreams/paranoid_rights_datastream.rb +3 -3
  286. data/sufia-models/app/models/file_usage.rb +53 -0
  287. data/sufia-models/app/models/follow.rb +2 -4
  288. data/sufia-models/app/models/geo_names_resource.rb +5 -7
  289. data/sufia-models/app/models/local_authority.rb +14 -14
  290. data/sufia-models/app/models/single_use_link.rb +1 -1
  291. data/sufia-models/app/models/sufia/download.rb +9 -0
  292. data/sufia-models/app/models/trophy.rb +1 -1
  293. data/sufia-models/app/services/sufia/{usage_statistics.rb → analytics.rb} +1 -24
  294. data/sufia-models/app/services/sufia/id_service.rb +2 -2
  295. data/sufia-models/lib/generators/sufia/models/install_generator.rb +5 -2
  296. data/sufia-models/lib/generators/sufia/models/templates/config/setup_mail.rb +1 -1
  297. data/sufia-models/lib/generators/sufia/models/templates/config/sufia.rb +5 -3
  298. data/sufia-models/lib/generators/sufia/models/templates/migrations/acts_as_follower_migration.rb +6 -6
  299. data/sufia-models/lib/generators/sufia/models/templates/migrations/create_checksum_audit_logs.rb +2 -3
  300. data/sufia-models/lib/generators/sufia/models/templates/migrations/create_local_authorities.rb +20 -20
  301. data/sufia-models/lib/sufia/ability.rb +1 -1
  302. data/sufia-models/lib/sufia/models/engine.rb +3 -9
  303. data/sufia-models/lib/sufia/models/file_content/versions.rb +3 -3
  304. data/sufia-models/lib/sufia/models/jobs/active_fedora_pid_based_job.rb +6 -2
  305. data/sufia-models/lib/sufia/models/jobs/batch_update_job.rb +6 -10
  306. data/sufia-models/lib/sufia/models/jobs/characterize_job.rb +1 -13
  307. data/sufia-models/lib/sufia/models/jobs/create_derivatives_job.rb +14 -0
  308. data/sufia-models/lib/sufia/models/jobs/import_url_job.rb +27 -23
  309. data/sufia-models/lib/tasks/sufia-models_tasks.rake +1 -1
  310. data/sufia-models/sufia-models.gemspec +1 -1
  311. data/sufia.gemspec +7 -2
  312. data/tasks/jetty.rake +4 -4
  313. data/tasks/release.rake +8 -8
  314. data/tasks/sufia-db.rake +4 -4
  315. data/tasks/sufia-dev.rake +11 -5
  316. metadata +226 -95
  317. data/app/helpers/sufia_helper.rb +0 -93
  318. data/app/views/catalog/_bookmark_form.html.erb +0 -8
  319. data/app/views/catalog/_home_header.html.erb +0 -15
  320. data/app/views/catalog/_recents.html.erb +0 -17
  321. data/app/views/dashboard/_index_partials/_thumbnail_display.html.erb +0 -9
  322. data/app/views/layouts/_homepage_sidebar2.html.erb +0 -14
  323. data/lib/sufia/files_controller_behavior.rb +0 -253
  324. data/spec/helpers/generic_file_helper_spec.rb +0 -28
  325. data/spec/lib/sufia/usage_statistics_spec.rb +0 -75
  326. data/spec/models/characterize_job_spec.rb +0 -93
  327. data/spec/models/transcode_audio_job_spec.rb +0 -85
  328. data/spec/models/transcode_video_job_spec.rb +0 -31
  329. data/spec/views/dashboard/index_partials/_thumbnail_display.html.erb_spec.rb +0 -22
  330. data/sufia-models/lib/sufia/models/generic_file/actions.rb +0 -50
  331. data/sufia-models/lib/sufia/models/generic_file/derivatives.rb +0 -31
  332. data/sufia-models/lib/sufia/models/generic_file/thumbnail.rb +0 -37
  333. data/sufia-models/lib/sufia/models/generic_file/versions.rb +0 -16
  334. data/sufia-models/lib/sufia/models/jobs/transcode_audio_job.rb +0 -15
  335. data/sufia-models/lib/sufia/models/jobs/transcode_video_job.rb +0 -15
@@ -19,20 +19,28 @@
19
19
  </tr>
20
20
  <tr>
21
21
  <th>Audit Status</th>
22
- <%- stat= @generic_file.audit_stat(false) %>
23
- <td> <%= (stat == 1 ? 'passing' : (stat == 0 ? 'failing' : stat)) %></td>
22
+ <%- stat = @generic_file.audit_stat(false)
23
+ audit = case stat
24
+ when 0
25
+ 'failing'
26
+ when 1
27
+ 'passing'
28
+ else
29
+ stat
30
+ end
31
+ -%>
32
+ <td><%= audit %></td>
24
33
  </tr>
25
34
  <% unless @generic_file.related_files.empty? %>
26
- <tr>
27
-
35
+ <tr>
28
36
  <th>Related Files</th>
29
37
  <td>
30
38
  <div class="related-files">
31
- <dl><dt>
39
+ <dl><dt>
32
40
  <% @generic_file.related_files.each do |f| %>
33
41
  <dd><%= link_to(f.label, sufia.generic_file_url(f.noid)) %></dd>
34
42
  <% end %>
35
- </dt></dl>
43
+ </dt></dl>
36
44
  </div>
37
45
  </td>
38
46
  </tr>
@@ -55,10 +63,10 @@
55
63
  <% values[0..length].each_with_index do |value, idx| %>
56
64
  <% next if value.empty? %>
57
65
  <%= "#{label}: #{value.truncate(250)}" %>
58
- <%= "<br />".html_safe unless idx == length %>
66
+ <%= "<br />".html_safe unless idx == length %>
59
67
  <% end %>
60
68
  <% if length != values.length %>
61
- <%= render :partial => "generic_files/extra_fields_modal", :locals=>{:name=>term, :values=> values, :start=>Sufia.config.fits_message_length}%>
69
+ <%= render partial: "generic_files/extra_fields_modal", locals: {name: term, values: values, start: Sufia.config.fits_message_length}%>
62
70
  <% end %>
63
71
  <% else %>
64
72
  <%= "#{label}: #{values.truncate(250)}" %><br />
@@ -69,4 +77,3 @@
69
77
  </tr>
70
78
  </tbody>
71
79
  </table> <!-- /verticalheadings -->
72
-
@@ -1,7 +1,7 @@
1
1
  <div id="versioning_display" class="tab-pane">
2
2
  <h2>Versions</h2>
3
3
  <div class="well">
4
- <%= form_for @generic_file, :url => sufia.generic_file_path(@generic_file), :html => {:multipart => true, :class => 'form-horizontal'} do |f| %>
4
+ <%= form_for @generic_file, url: sufia.generic_file_path(@generic_file), html: {multipart: true, class: 'form-horizontal'} do |f| %>
5
5
  <%= hidden_field_tag('redirect_tab', 'versions') %>
6
6
  <h3>Upload New Version</h3>
7
7
  <div class="form-group">
@@ -10,7 +10,7 @@
10
10
  <p id="upload_field">
11
11
  <%= file_field_tag "filedata" %>
12
12
  </p>
13
- <%= f.button '<i class="glyphicon glyphicon-upload"></i> Upload New Version'.html_safe, :name => "update_versioning", :id => "upload_submit", :onclick => "confirmation_needed = false;", :class => "btn-primary btn-mini" %>
13
+ <%= f.button '<i class="glyphicon glyphicon-upload"></i> Upload New Version'.html_safe, name: "update_versioning", id: "upload_submit", onclick: "confirmation_needed = false;", class: "btn-primary btn-mini" %>
14
14
  </div>
15
15
  </div>
16
16
  <hr />
@@ -27,7 +27,7 @@
27
27
  </div>
28
28
  <% end %>
29
29
  <div id="save_version_note" class="alert hide">You must click &quot;Save Revision&quot; to revert a previous version of this file</div>
30
- <%= f.button '<i class="glyphicon glyphicon-save"></i> Save Revision'.html_safe, :type => 'submit', :class => 'btn-primary btn-mini', :onclick => "confirmation_needed = false;", :name => "revert_submit", :id => "revert_submit" %>
30
+ <%= f.button '<i class="glyphicon glyphicon-save"></i> Save Revision'.html_safe, type: 'submit', class: 'btn-primary btn-mini', onclick: "confirmation_needed = false;", name: "revert_submit", id: "revert_submit" %>
31
31
  <% end %>
32
32
  </div> <!-- /well -->
33
33
  </div> <!-- /row -->
@@ -11,12 +11,12 @@ $('input[name=revision]:radio').on('click', function() {
11
11
  confirmation_needed = false;
12
12
  window.onbeforeunload = confirmExit;
13
13
  function confirmExit(){
14
- if(confirmation_needed){
14
+ if(confirmation_needed){
15
15
  // if you return a string it will be displayed in between "don't navigate away"
16
16
  // and "click Ok to navigate away or cancel to stay put" in the confirm dialog
17
17
  return "Your metadata has not been saved.";
18
18
  }
19
- }
19
+ }
20
20
  // only valid for perm tab
21
21
  set_access_levels();
22
22
 
@@ -25,12 +25,12 @@ $("a[rel=popover]").popover({ html: true });
25
25
 
26
26
  <% end %>
27
27
 
28
- <%= render :partial => 'breadcrumbs' %>
28
+ <%= render partial: 'breadcrumbs' %>
29
29
  <h1 class="lower">Edit <%= @generic_file %></h1>
30
30
 
31
31
  <div class="row">
32
32
  <div class="col-xs-12 col-sm-4">
33
- <%= render :partial => 'media_display' %>
33
+ <%= render partial: 'media_display' %>
34
34
  </div>
35
35
  <div class="col-xs-12 col-sm-8">
36
36
  <%= link_to "&lt;&lt;Browse view".html_safe, sufia.generic_file_path(@generic_file) %>
@@ -40,9 +40,9 @@ $("a[rel=popover]").popover({ html: true });
40
40
  <li id="edit_permissions_link"><a href="#permissions_display" data-toggle="tab"><i class="glyphicon glyphicon-key"></i> Permissions</a></li>
41
41
  </ul>
42
42
  <div class="tab-content">
43
- <%= render :partial => "descriptions", :locals => { :generic_file => @generic_file } %>
44
- <%= render :partial => "permission", :locals => { :gf => @generic_file} %>
45
- <%= render :partial => "versioning", :locals => { :generic_file => @generic_file } %>
43
+ <%= render partial: "descriptions", locals: { generic_file: @generic_file } %>
44
+ <%= render partial: "permission", locals: { gf: @generic_file} %>
45
+ <%= render partial: "versioning", locals: { generic_file: @generic_file } %>
46
46
  </div>
47
47
  </div> <!-- /.col-sm-9 -->
48
48
  </div><!-- /.row -->
@@ -1,7 +1,6 @@
1
1
  <div class="col-sm-9" <% if index == 0 %> id="additional_<%= key.to_s %>_clone" <% end %>>
2
2
  <% required = render_req && (index == 0) && required?(key) %>
3
- <%= f.text_field :title, :name=>"generic_file[#{key.to_s}][]", :id => "generic_file_"+key.to_s, :value=>v, :class => "input-large", :required => required %>
4
- <%= render :partial=>"generic_files/edit_fields/suffix", :locals=>{key: key, index: index} %>
5
- </div><!-- /controls -->
3
+ <%= f.text_field :title, name: "generic_file[#{key.to_s}][]", id: "generic_file_#{key.to_s}", value: v, class: "input-large", required: required %>
4
+ <%= render partial: "generic_files/edit_fields/suffix", locals: { key: key, index: index } %>
5
+ </div><!-- /controls -->
6
6
  <div id="additional_<%= key %>_elements"></div>
7
-
@@ -1,6 +1,5 @@
1
1
  <div class="col-sm-9" <% if index == 0%> id="additional_<%= key.to_s %>_clone" <% end %>>
2
- <%= f.text_area :description, :name=>"generic_file[#{key.to_s}][]", :id => "generic_file_"+key.to_s, :value=>v, :class => "input-large" %>
3
- <%= render :partial=>"generic_files/edit_fields/suffix", :locals=>{key: key, index: index} %>
4
- </div><!-- /controls -->
2
+ <%= f.text_area :description, name:"generic_file[#{key.to_s}][]", id: "generic_file_{key.to_s}", value: v, class: "input-large" %>
3
+ <%= render partial: "generic_files/edit_fields/suffix", locals: { key: key, index: index } %>
4
+ </div><!-- /controls -->
5
5
  <div id="additional_<%= key %>_elements"></div>
6
-
@@ -1,8 +1,6 @@
1
1
  <%# convert class variable to a local variable if the local hasn't been set %>
2
2
  <% generic_file = @generic_file unless generic_file %>
3
-
4
3
  <div class="col-sm-9">
5
- <%= f.select "resource_type", options_for_select(Sufia.config.resource_types.keys, generic_file.resource_type), {}, {:multiple=>true, :size=>7} %>
4
+ <%= f.select "resource_type", options_for_select(Sufia.config.resource_types.keys, generic_file.resource_type), {}, { multiple: true, size: 7 } %>
6
5
  <p class="help-block">You may select multiple types to apply <%= help_icon(:resource_type) %><p>
7
6
  </div>
8
-
@@ -1,8 +1,6 @@
1
1
  <div class="col-sm-9" <% if index == 0%> id="additional_<%= key.to_s %>_clone" <% end %>>
2
- <% choices = Sufia.config.cc_licenses %>
3
- <% choices = {""=>""}.merge(choices) %>
2
+ <% choices = {"" => ""}.merge(Sufia.config.cc_licenses) %>
4
3
  <%= f.select "rights", options_for_select(choices, v) %>
5
- <%= render :partial=>"generic_files/edit_fields/suffix", :locals=>{key: key, index: index} %>
6
- </div><!-- /controls -->
4
+ <%= render partial: "generic_files/edit_fields/suffix", locals: { key: key, index: index } %>
5
+ </div><!-- /controls -->
7
6
  <div id="additional_<%= key %>_elements"></div>
8
-
@@ -2,7 +2,7 @@
2
2
  <%= add_field(key) %>
3
3
  &nbsp;
4
4
  <%= help_icon(key) %>
5
- <%= render :partial => "generic_files/rights_modal" if key == "rights" %>
5
+ <%= render partial: "generic_files/rights_modal" if key == "rights" %>
6
6
  <% else %>
7
7
  <%= subtract_field(key) %>
8
8
  <% end %>
@@ -9,18 +9,18 @@
9
9
  initialize_audio();
10
10
  <% end %>
11
11
 
12
- <%= render :partial => 'generic_files/breadcrumbs' %>
12
+ <%= render partial: 'generic_files/breadcrumbs' %>
13
13
  <div class="container-fluid">
14
14
  <div class="row">
15
15
  <div class="col-xs-12 col-sm-4">
16
- <%= render :partial => 'generic_files/media_display' %>
16
+ <%= render partial: 'generic_files/media_display' %>
17
17
  <%= render partial: 'show_actions' %>
18
18
  </div>
19
19
  <div itemscope itemtype="http://schema.org/CreativeWork" class="col-xs-12 col-sm-8">
20
20
  <h1><%= @generic_file %></h1>
21
21
  <%= render partial: 'show_descriptions' %>
22
22
  <%= render partial: 'show_details' %>
23
- <%= render :partial => 'users/activity_log', :locals => {:events => @events} %>
23
+ <%= render partial: 'users/activity_log', locals: {events: @events} %>
24
24
  </div><!-- /columns second -->
25
25
  </div> <!-- /.row -->
26
26
  </div><!-- /.container-fluid -->
@@ -1,135 +1,19 @@
1
- <%= render :partial => 'generic_files/breadcrumbs' %>
1
+ <%= render partial: 'generic_files/breadcrumbs' %>
2
2
 
3
3
  <!-- Adapted from jquery-flot examples https://github.com/flot/flot/blob/master/examples/visitors/index.html -->
4
4
  <!--[if lte IE 8]><%= javascript_include_tag 'excanvas' %><![endif]-->
5
- <script type="text/javascript">
6
- $(function() {
5
+ <%= javascript_tag do %>
6
+ <%= render partial: 'generic_files/flot_stats', formats: [:js] %>
7
+ <% end %>
7
8
 
8
- var d = <%= @stats_json.html_safe %>;
9
-
10
- function weekendAreas(axes) {
11
- var markings = [],
12
- d = new Date(axes.xaxis.min);
13
-
14
- // go to the first Saturday
15
-
16
- d.setUTCDate(d.getUTCDate() - ((d.getUTCDay() + 1) % 7))
17
- d.setUTCSeconds(0);
18
- d.setUTCMinutes(0);
19
- d.setUTCHours(0);
20
-
21
- var i = d.getTime();
22
-
23
- // when we don't set yaxis, the rectangle automatically
24
- // extends to infinity upwards and downwards
25
-
26
- do {
27
- markings.push({ xaxis: { from: i, to: i + 2 * 24 * 60 * 60 * 1000 } });
28
- i += 7 * 24 * 60 * 60 * 1000;
29
- } while (i < axes.xaxis.max);
30
-
31
- return markings;
32
- }
33
-
34
- var options = {
35
- xaxis: {
36
- mode: "time",
37
- tickLength: 5
38
- },
39
- yaxis: {
40
- tickDecimals: 0,
41
- min: 0
42
- },
43
- series: {
44
- lines: {
45
- show: true,
46
- fill: true
47
- },
48
- points: {
49
- show: true,
50
- fill: true
51
- }
52
- },
53
- selection: {
54
- mode: "x"
55
- },
56
- grid: {
57
- hoverable: true,
58
- clickable: true,
59
- markings: weekendAreas
60
- }
61
- };
62
-
63
- var plot = $.plot("#usage-stats", [d], options);
64
-
65
- $("<div id='tooltip'></div>").css({
66
- position: "absolute",
67
- display: "none",
68
- border: "1px solid #bce8f1",
69
- padding: "2px",
70
- "background-color": "#d9edf7",
71
- opacity: 0.80
72
- }).appendTo("body");
73
-
74
- $("#usage-stats").bind("plothover", function (event, pos, item) {
75
- if (item) {
76
- date = new Date(item.datapoint[0]);
77
- months = ["January", "February", "March", "April", "May", "June",
78
- "July", "August", "September", "October", "November", "December"]
79
- $("#tooltip").html("<strong>Views: " + item.datapoint[1] + "</strong><br/>" + months[date.getMonth()] + " " + date.getDate() + ", " + date.getFullYear())
80
- .css({top: item.pageY+5, left: item.pageX+5})
81
- .fadeIn(200);
82
- } else {
83
- $("#tooltip").fadeOut(100)
84
- }
85
- });
86
-
87
- var overview = $.plot("#overview", [d], {
88
- series: {
89
- lines: {
90
- show: true,
91
- lineWidth: 1
92
- },
93
- shadowSize: 0
94
- },
95
- xaxis: {
96
- ticks: [],
97
- mode: "time",
98
- minTickSize: [1, "day"]
99
- },
100
- yaxis: {
101
- ticks: [],
102
- min: 0,
103
- autoscaleMargin: 0.1
104
- },
105
- selection: {
106
- mode: "x"
107
- }
108
- });
109
-
110
- $("#usage-stats").bind("plotselected", function(event, ranges) {
111
- plot = $.plot("#usage-stats", [d], $.extend(true, {}, options, {
112
- xaxis: {
113
- min: ranges.xaxis.from,
114
- max: ranges.xaxis.to
115
- }
116
- }));
117
- overview.setSelection(ranges, true);
118
- });
119
-
120
- $("#overview").bind("plotselected", function(event, ranges) {
121
- plot.setSelection(ranges);
122
- });
123
- });
124
- </script>
125
-
126
- <h1 class="lower"><%= @generic_file %></h1>
9
+ <%= content_tag :h1, @generic_file, class: "lower" %>
127
10
 
128
11
  <div class="row">
129
12
  <div class="span110">
130
- <h2>Usage Statistics</h2>
13
+ <%= content_tag :h2, "Analytics" %>
131
14
  <div class="alert alert-info">
132
- <i class="icon-bar-chart icon-large"></i> <strong><%= @pageviews %></strong> views since <%= @created.strftime("%B %-d, %Y") %>
15
+ <i class="icon-bar-chart icon-large"></i>
16
+ <%= content_tag :strong, @stats.total_pageviews %> views and <%= content_tag :strong, @stats.total_downloads %> downloads since <%= @stats.created.strftime("%B %-d, %Y") %>
133
17
  </div>
134
18
  <div class="stats-container">
135
19
  <div id="usage-stats" class="stats-placeholder"></div>
@@ -1,8 +1,7 @@
1
-
2
1
  <div class="alert alert-info hide" id="success">
3
2
  You have successfully uploaded some of your files. Either continue to upload or edit use the links below to abandon the rest of your added files.
4
3
  <p>
5
- <%= link_to 'Add Descriptions', GenericFilesController.upload_complete_path(@batch_noid), :class=>'btn' %>
4
+ <%= link_to 'Add Descriptions', GenericFilesController.upload_complete_path(@batch_noid), class: 'btn' %>
6
5
  </p>
7
6
  </div>
8
7
 
@@ -12,8 +11,7 @@
12
11
 
13
12
  <div class="alert hide" id="partial_fail">
14
13
  One or more files did not upload successfully. To continue using the files uploaded use one of the links below.<br />
15
- <%= link_to 'Add Descriptions', GenericFilesController.upload_complete_path(@batch_noid), :class=>'btn' %>
14
+ <%= link_to 'Add Descriptions', GenericFilesController.upload_complete_path(@batch_noid), class: 'btn' %>
16
15
  </div>
17
16
 
18
17
  <div class="alert hide" id="errmsg"> </div>
19
-
@@ -1,4 +1,4 @@
1
- <%= form_for(@generic_file, :url => sufia.generic_files_path, :html => {:multipart => true, :id => 'fileupload'}) do |f| %>
1
+ <%= form_for(@generic_file, url: sufia.generic_files_path, html: {multipart: true, id: 'fileupload'}) do |f| %>
2
2
  <div class="well">
3
3
  <%= render partial: 'generic_files/upload/form_fields' %>
4
4
  </div>
@@ -1,7 +1,7 @@
1
1
  <% if current_user.directory.present? %>
2
2
  <div class="well">
3
3
  <%= render partial: 'generic_files/upload/tos_checkbox' %>
4
- <%= form_for @generic_file, :url => sufia.generic_files_path, :html => { :class => 'form-horizontal well'} do |f| %>
4
+ <%= form_for @generic_file, url: sufia.generic_files_path, html: { class: 'form-horizontal well'} do |f| %>
5
5
  <table class="table table-striped">
6
6
  <caption>Select files to deposit from your user directory on the server.</caption>
7
7
  <thead>
@@ -1,3 +1,3 @@
1
1
  <label class="checkbox">
2
- <%= check_box_tag 'terms_of_service', 1, nil, {"data-activate" => 'activate-submit'} %> I have read and do agree to <%= link_to t('sufia.deposit_agreement'), '/agreement/', :target => "_blank" %>.
2
+ <%= check_box_tag 'terms_of_service', 1, nil, {"data-activate" => 'activate-submit'} %> I have read and do agree to <%= link_to t('sufia.deposit_agreement'), '/agreement/', target: "_blank" %>.
3
3
  </label>
@@ -2,7 +2,9 @@
2
2
  <li class="featured-item" data-id="<%= solr_document.noid %>">
3
3
  <div class="main row">
4
4
  <div class="col-sm-3">
5
- <%= render partial: 'dashboard/_index_partials/thumbnail_display', locals: {document: solr_document, width: 90} %>
5
+ <%= link_to sufia.generic_file_path(solr_document) do %>
6
+ <%= render_thumbnail_tag solr_document, {width: 90} %>
7
+ <% end %>
6
8
  </div>
7
9
  <div class="col-sm-9">
8
10
  <%= render partial: 'homepage/featured_fields', locals: {featured: solr_document} %>
@@ -4,3 +4,4 @@
4
4
  <div id="home_content" class="row">
5
5
  <%= render partial: 'home_content' %>
6
6
  </div>
7
+ <%= tiny_mce_stuff if can? :update, ContentBlock%>
@@ -5,10 +5,10 @@
5
5
  </ul>
6
6
  <div class="tab-content">
7
7
  <div class="tab-pane fade in" id="highlighted_resources">
8
- <%= render :partial=>'/homepage/featured_works' %>
8
+ <%= render partial: '/homepage/featured_works' %>
9
9
  </div>
10
10
  <div class="tab-pane fade" id="recently_uploaded">
11
- <%= render :partial=>'/catalog/recents', :locals => {:recent_documents=>@recent_documents, :msg=>"No public work has been contributed.", :display_thumbs=>true, :display_access=>false} %>
11
+ <%= render partial: 'recents', locals: { recent_documents: @recent_documents, msg: "No public work has been contributed.", display_thumbs: true, display_access: false } %>
12
12
  </div>
13
13
  </div>
14
14
  </div><!-- /.col-xs-6 -->
@@ -17,12 +17,12 @@
17
17
  <%- if blacklight_config.respond_to?(:tag_cloud_field_name) && blacklight_config.tag_cloud_field_name %>
18
18
  <div class="row">
19
19
  <h2 class="heading1 pull-left">Explore</h2>
20
- <%= render partial:'catalog/tagcloud', locals:{tag_cloud_field_name:blacklight_config.tag_cloud_field_name}%>
20
+ <%= render partial: 'tagcloud', locals: { tag_cloud_field_name: blacklight_config.tag_cloud_field_name } %>
21
21
  </div>
22
22
  <%- end %>
23
23
  </div>
24
24
  <div>
25
- <%= render :partial=>'/catalog/featured_researcher' %>
25
+ <%= render partial: 'featured_researcher' %>
26
26
  </div>
27
27
  </div>
28
28
  <script>
@@ -0,0 +1,12 @@
1
+ <div class="home_call_action col-xs-12 col-sm-4 pull-right">
2
+ <div class="home_share_work">
3
+ <%= link_to "<i class=\"icon-file\"></i> #{t('sufia.share_button')}".html_safe, sufia.new_generic_file_path, class: "btn btn-primary btn-lg btn-block", id: "contribute_link" %>
4
+ <p class="text-center"><a href="/terms/">Terms of Use</a></p>
5
+ </div><!-- /.home_share_work -->
6
+ </div><!-- /.col-xs-3 -->
7
+ <div class="col-xs-12 col-sm-8">
8
+ <%= render partial: "marketing" %>
9
+ </div>
10
+
11
+
12
+