enju_circulation 0.4.0.beta.4 → 0.4.0.rc.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (324) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -1
  3. data/app/models/carrier_type_has_checkout_type.rb +5 -5
  4. data/app/models/checked_item.rb +7 -7
  5. data/app/models/checkin.rb +7 -7
  6. data/app/models/checkout.rb +10 -10
  7. data/app/models/checkout_stat_has_manifestation.rb +5 -5
  8. data/app/models/checkout_stat_has_user.rb +5 -5
  9. data/app/models/checkout_type.rb +3 -3
  10. data/app/models/circulation_status.rb +3 -3
  11. data/app/models/concerns/enju_circulation/enju_item.rb +15 -2
  12. data/app/models/concerns/enju_circulation/enju_withdraw.rb +7 -1
  13. data/app/models/demand.rb +4 -4
  14. data/app/models/item_has_use_restriction.rb +5 -5
  15. data/app/models/manifestation_checkout_stat.rb +4 -14
  16. data/app/models/manifestation_checkout_stat_transition.rb +3 -3
  17. data/app/models/manifestation_reserve_stat.rb +4 -14
  18. data/app/models/manifestation_reserve_stat_transition.rb +3 -3
  19. data/app/models/reserve.rb +8 -17
  20. data/app/models/reserve_stat_has_manifestation.rb +5 -5
  21. data/app/models/reserve_stat_has_user.rb +5 -5
  22. data/app/models/reserve_transition.rb +3 -3
  23. data/app/models/use_restriction.rb +3 -3
  24. data/app/models/user_checkout_stat.rb +4 -14
  25. data/app/models/user_checkout_stat_transition.rb +3 -3
  26. data/app/models/user_group_has_checkout_type.rb +5 -5
  27. data/app/models/user_reserve_stat.rb +4 -14
  28. data/app/models/user_reserve_stat_transition.rb +3 -3
  29. data/app/views/checked_items/edit.html.erb +0 -5
  30. data/app/views/checkouts/_list.html.erb +7 -0
  31. data/app/views/user_group_has_checkout_types/index.html.erb +2 -2
  32. data/config/locales/translation_en.yml +12 -0
  33. data/config/locales/translation_ja.yml +12 -0
  34. data/db/migrate/032_create_checkins.rb +1 -1
  35. data/db/migrate/033_create_checkouts.rb +1 -1
  36. data/db/migrate/035_create_reserves.rb +2 -7
  37. data/db/migrate/121_create_checked_items.rb +1 -1
  38. data/db/migrate/127_create_use_restrictions.rb +1 -1
  39. data/db/migrate/129_create_item_has_use_restrictions.rb +1 -1
  40. data/db/migrate/132_create_circulation_statuses.rb +1 -1
  41. data/db/migrate/20081030023412_create_checkout_types.rb +1 -1
  42. data/db/migrate/20081030023518_create_user_group_has_checkout_types.rb +1 -1
  43. data/db/migrate/20081030023615_create_carrier_type_has_checkout_types.rb +1 -1
  44. data/db/migrate/20081212075554_create_checkout_stat_has_manifestations.rb +1 -1
  45. data/db/migrate/20081212080038_create_manifestation_checkout_stats.rb +1 -1
  46. data/db/migrate/20081215094302_create_user_checkout_stats.rb +1 -1
  47. data/db/migrate/20081215094955_create_checkout_stat_has_users.rb +1 -1
  48. data/db/migrate/20081216190517_create_reserve_stat_has_manifestations.rb +1 -1
  49. data/db/migrate/20081216190724_create_manifestation_reserve_stats.rb +1 -1
  50. data/db/migrate/20081220023628_create_user_reserve_stats.rb +1 -1
  51. data/db/migrate/20081220034117_create_reserve_stat_has_users.rb +1 -1
  52. data/db/migrate/20090321130448_add_completed_at_to_user_checkout_stat.rb +1 -1
  53. data/db/migrate/20110301134521_add_expire_date_to_reserve.rb +1 -1
  54. data/db/migrate/20110328130826_add_current_checkout_count_to_user_group_has_checkout_type.rb +1 -1
  55. data/db/migrate/20110621093332_remove_expire_date_from_reserve.rb +1 -1
  56. data/db/migrate/20110627122938_add_number_of_day_to_notify_overdue_to_user_group.rb +4 -4
  57. data/db/migrate/20111129044509_add_pickup_location_to_reserve.rb +1 -1
  58. data/db/migrate/20120424103932_add_librarian_id_to_checked_item.rb +1 -1
  59. data/db/migrate/20130303124821_add_retained_at_to_reserve.rb +1 -1
  60. data/db/migrate/20130304015019_add_postponed_at_to_reserve.rb +1 -1
  61. data/db/migrate/20130416054135_add_circulation_status_id_to_item.rb +1 -1
  62. data/db/migrate/20130519065638_add_lock_version_to_reserve.rb +1 -1
  63. data/db/migrate/20130519065837_add_lock_version_to_checkin.rb +1 -1
  64. data/db/migrate/20140518050147_create_reserve_transitions.rb +1 -1
  65. data/db/migrate/20140528045518_create_user_checkout_stat_transitions.rb +1 -1
  66. data/db/migrate/20140528045539_create_user_reserve_stat_transitions.rb +1 -1
  67. data/db/migrate/20140528045600_create_manifestation_checkout_stat_transitions.rb +1 -1
  68. data/db/migrate/20140528045617_create_manifestation_reserve_stat_transitions.rb +1 -1
  69. data/db/migrate/20140810061942_add_user_id_to_user_checkout_stat.rb +1 -1
  70. data/db/migrate/20140810091231_add_checkout_icalendar_token_to_profile.rb +1 -1
  71. data/db/migrate/20140810091417_add_save_checkout_history_to_profile.rb +1 -1
  72. data/db/migrate/20141014065831_add_shelf_id_to_checkout.rb +1 -1
  73. data/db/migrate/20141020120523_add_library_id_to_checkout.rb +1 -1
  74. data/db/migrate/20150106001709_create_demands.rb +1 -1
  75. data/db/migrate/20160703184619_add_most_recent_to_reserve_transitions.rb +1 -1
  76. data/db/migrate/20160703184650_add_most_recent_to_manifestation_checkout_stat_transitions.rb +1 -1
  77. data/db/migrate/20160703184723_add_most_recent_to_manifestation_reserve_stat_transitions.rb +1 -1
  78. data/db/migrate/20160703184747_add_most_recent_to_user_checkout_stat_transitions.rb +1 -1
  79. data/db/migrate/20160703184805_add_most_recent_to_user_reserve_stat_transitions.rb +1 -1
  80. data/db/migrate/20160703190209_add_foreign_key_on_manifestation_id_to_reserve.rb +1 -1
  81. data/db/migrate/20180107161035_add_constraints_to_most_recent_for_reserve_transitions.rb +1 -1
  82. data/db/migrate/20180107161951_add_constraints_to_most_recent_for_user_checkout_stat_transitions.rb +1 -1
  83. data/db/migrate/20180107162009_add_constraints_to_most_recent_for_user_reserve_stat_transitions.rb +1 -1
  84. data/db/migrate/20180107162029_add_constraints_to_most_recent_for_manifestation_checkout_stat_transitions.rb +1 -1
  85. data/db/migrate/20180107162048_add_constraints_to_most_recent_for_manifestation_reserve_stat_transitions.rb +1 -1
  86. data/db/migrate/20190713114724_add_checkout_id_to_checkin.rb +1 -1
  87. data/lib/enju_circulation/version.rb +1 -1
  88. data/spec/controllers/items_controller_spec.rb +34 -0
  89. data/spec/dummy/app/controllers/application_controller.rb +0 -1
  90. data/spec/dummy/app/helpers/application_helper.rb +0 -2
  91. data/spec/dummy/app/models/user.rb +0 -1
  92. data/spec/dummy/config/application.rb +0 -1
  93. data/spec/dummy/db/migrate/001_create_agents.rb +1 -2
  94. data/spec/dummy/db/migrate/005_create_manifestations.rb +1 -2
  95. data/spec/dummy/db/migrate/006_create_items.rb +1 -2
  96. data/spec/dummy/db/migrate/012_create_owns.rb +1 -3
  97. data/spec/dummy/db/migrate/015_create_creates.rb +1 -3
  98. data/spec/dummy/db/migrate/041_create_roles.rb +1 -1
  99. data/spec/dummy/db/migrate/047_create_produces.rb +1 -3
  100. data/spec/dummy/db/migrate/059_create_libraries.rb +1 -2
  101. data/spec/dummy/db/migrate/069_create_shelves.rb +1 -2
  102. data/spec/dummy/db/migrate/073_create_carrier_types.rb +1 -1
  103. data/spec/dummy/db/migrate/077_create_user_groups.rb +1 -2
  104. data/spec/dummy/db/migrate/080_create_library_groups.rb +1 -1
  105. data/spec/dummy/db/migrate/112_create_frequencies.rb +1 -1
  106. data/spec/dummy/db/migrate/117_create_form_of_works.rb +1 -1
  107. data/spec/dummy/db/migrate/120_create_baskets.rb +1 -1
  108. data/spec/dummy/db/migrate/124_create_bookstores.rb +1 -2
  109. data/spec/dummy/db/migrate/125_create_donates.rb +1 -1
  110. data/spec/dummy/db/migrate/130_create_request_status_types.rb +1 -1
  111. data/spec/dummy/db/migrate/131_create_request_types.rb +1 -1
  112. data/spec/dummy/db/migrate/133_create_agent_merges.rb +1 -1
  113. data/spec/dummy/db/migrate/134_create_agent_merge_lists.rb +1 -1
  114. data/spec/dummy/db/migrate/20080830154109_create_realizes.rb +1 -3
  115. data/spec/dummy/db/migrate/20080905191442_create_agent_types.rb +1 -1
  116. data/spec/dummy/db/migrate/20081006090811_create_subscriptions.rb +1 -2
  117. data/spec/dummy/db/migrate/20081006093246_create_subscribes.rb +1 -1
  118. data/spec/dummy/db/migrate/20081023092436_create_search_engines.rb +1 -1
  119. data/spec/dummy/db/migrate/20081025083323_create_countries.rb +1 -1
  120. data/spec/dummy/db/migrate/20081025083905_create_languages.rb +1 -1
  121. data/spec/dummy/db/migrate/20081027150907_create_picture_files.rb +1 -1
  122. data/spec/dummy/db/migrate/20081028083142_create_agent_import_files.rb +1 -1
  123. data/spec/dummy/db/migrate/20081028083208_create_resource_import_files.rb +1 -1
  124. data/spec/dummy/db/migrate/20090705133942_add_attachments_picture_to_picture_file.rb +1 -1
  125. data/spec/dummy/db/migrate/20090705212043_add_attachments_attachment_to_manifestation.rb +1 -1
  126. data/spec/dummy/db/migrate/20090720091106_create_medium_of_performances.rb +1 -1
  127. data/spec/dummy/db/migrate/20090720091429_create_content_types.rb +1 -1
  128. data/spec/dummy/db/migrate/20090812151902_create_agent_relationship_types.rb +1 -1
  129. data/spec/dummy/db/migrate/20091012101112_add_dcndl_schema.rb +1 -1
  130. data/spec/dummy/db/migrate/20091025080447_create_licenses.rb +1 -1
  131. data/spec/dummy/db/migrate/20091214131723_create_series_statements.rb +1 -1
  132. data/spec/dummy/db/migrate/20100129142347_create_import_requests.rb +1 -1
  133. data/spec/dummy/db/migrate/20100211105551_add_admin_networks_to_library_group.rb +1 -1
  134. data/spec/dummy/db/migrate/20100223121519_rename_series_statement_title_to_original_title.rb +1 -1
  135. data/spec/dummy/db/migrate/20100314190054_add_opening_hour_to_library.rb +1 -1
  136. data/spec/dummy/db/migrate/20100321235924_add_series_statement_identifier_to_series_statement.rb +1 -1
  137. data/spec/dummy/db/migrate/20100525124311_create_manifestation_relationships.rb +1 -1
  138. data/spec/dummy/db/migrate/20100606065209_create_user_has_roles.rb +1 -1
  139. data/spec/dummy/db/migrate/20100606073747_create_agent_relationships.rb +1 -1
  140. data/spec/dummy/db/migrate/20100607044753_create_manifestation_relationship_types.rb +1 -1
  141. data/spec/dummy/db/migrate/20100814091104_add_position_to_agent_relationship.rb +1 -1
  142. data/spec/dummy/db/migrate/20100925043847_create_resource_import_results.rb +1 -1
  143. data/spec/dummy/db/migrate/20100925074559_create_agent_import_results.rb +1 -1
  144. data/spec/dummy/db/migrate/20101212070145_add_acquired_at_to_item.rb +1 -1
  145. data/spec/dummy/db/migrate/20110222073537_add_url_to_library_group.rb +1 -1
  146. data/spec/dummy/db/migrate/20110301035123_add_pub_date_to_manifestation.rb +1 -1
  147. data/spec/dummy/db/migrate/20110301121550_add_birth_date_and_death_date_to_agent.rb +1 -1
  148. data/spec/dummy/db/migrate/20110318183304_add_valid_period_for_new_user_to_user_group.rb +1 -1
  149. data/spec/dummy/db/migrate/20110603184217_add_edit_mode_to_resource_import_file.rb +1 -1
  150. data/spec/dummy/db/migrate/20110619064807_add_edition_string_to_manifestation.rb +1 -1
  151. data/spec/dummy/db/migrate/20110620173525_add_bookstore_id_to_item.rb +1 -1
  152. data/spec/dummy/db/migrate/20110627034940_create_series_statement_merge_lists.rb +1 -1
  153. data/spec/dummy/db/migrate/20110627035057_create_series_statement_merges.rb +1 -1
  154. data/spec/dummy/db/migrate/20110916091020_add_volume_number_to_manifestation.rb +1 -1
  155. data/spec/dummy/db/migrate/20110916103953_add_manifestaiton_id_to_series_statement.rb +1 -1
  156. data/spec/dummy/db/migrate/20110918162329_add_note_to_series_statement.rb +1 -1
  157. data/spec/dummy/db/migrate/20111124110059_create_create_types.rb +1 -1
  158. data/spec/dummy/db/migrate/20111124110319_create_realize_types.rb +1 -1
  159. data/spec/dummy/db/migrate/20111124110355_create_produce_types.rb +1 -1
  160. data/spec/dummy/db/migrate/20111124112131_add_create_type_to_create.rb +1 -1
  161. data/spec/dummy/db/migrate/20120105074911_add_isil_to_library.rb +1 -1
  162. data/spec/dummy/db/migrate/20120125152919_add_title_subseries_transcription_to_series_statement.rb +1 -1
  163. data/spec/dummy/db/migrate/20120129014038_create_budget_types.rb +1 -1
  164. data/spec/dummy/db/migrate/20120129020544_add_budget_type_id_to_item.rb +1 -1
  165. data/spec/dummy/db/migrate/20120319120638_add_content_type_id_to_manifestation.rb +1 -1
  166. data/spec/dummy/db/migrate/20120319173203_create_accepts.rb +1 -1
  167. data/spec/dummy/db/migrate/20120410104851_add_year_of_publication_to_manifestation.rb +1 -1
  168. data/spec/dummy/db/migrate/20120413072700_add_picture_meta_to_picture_file.rb +1 -1
  169. data/spec/dummy/db/migrate/20120413100352_add_fingerprint_to_picture_file.rb +1 -1
  170. data/spec/dummy/db/migrate/20120413161340_add_fingerprint_to_resource_import_file.rb +1 -1
  171. data/spec/dummy/db/migrate/20120413161403_add_fingerprint_to_agent_import_file.rb +1 -1
  172. data/spec/dummy/db/migrate/20120413170705_add_error_message_to_resource_import_file.rb +1 -1
  173. data/spec/dummy/db/migrate/20120413170720_add_error_message_to_agent_import_file.rb +1 -1
  174. data/spec/dummy/db/migrate/20120415164821_add_attachment_meta_to_manifestation.rb +1 -1
  175. data/spec/dummy/db/migrate/20120418081407_add_month_of_publication_to_manifestation.rb +1 -1
  176. data/spec/dummy/db/migrate/20120510140958_add_closed_to_shelf.rb +1 -1
  177. data/spec/dummy/db/migrate/20120511072422_add_agent_identifier_to_agent.rb +1 -1
  178. data/spec/dummy/db/migrate/20120602141129_add_edit_mode_to_agent_import_file.rb +1 -1
  179. data/spec/dummy/db/migrate/20121116031206_add_fulltext_content_to_manifestation.rb +1 -1
  180. data/spec/dummy/db/migrate/20130221154434_add_additional_attributes_to_user.rb +1 -2
  181. data/spec/dummy/db/migrate/20130412083556_add_latitude_and_longitude_to_library.rb +1 -1
  182. data/spec/dummy/db/migrate/20130421093852_add_periodical_to_manifestation.rb +1 -1
  183. data/spec/dummy/db/migrate/20130421155019_add_creator_string_to_series_statement.rb +1 -1
  184. data/spec/dummy/db/migrate/20130421164124_add_series_master_to_series_statement.rb +1 -1
  185. data/spec/dummy/db/migrate/20130429020822_add_root_manifestation_id_to_series_statement.rb +1 -1
  186. data/spec/dummy/db/migrate/20130506175303_create_identifier_types.rb +1 -1
  187. data/spec/dummy/db/migrate/20130506175834_create_identifiers.rb +1 -1
  188. data/spec/dummy/db/migrate/20130509185724_add_statement_of_responsibility_to_manifestation.rb +1 -1
  189. data/spec/dummy/db/migrate/20140110122216_create_user_import_files.rb +1 -1
  190. data/spec/dummy/db/migrate/20140110131010_create_user_import_results.rb +1 -1
  191. data/spec/dummy/db/migrate/20140122054321_create_profiles.rb +1 -1
  192. data/spec/dummy/db/migrate/20140519170214_create_resource_import_file_transitions.rb +1 -1
  193. data/spec/dummy/db/migrate/20140519171220_create_import_request_transitions.rb +1 -1
  194. data/spec/dummy/db/migrate/20140524020735_create_agent_import_file_transitions.rb +1 -1
  195. data/spec/dummy/db/migrate/20140524074813_create_user_import_file_transitions.rb +2 -6
  196. data/spec/dummy/db/migrate/20140610123439_drop_email_unique_constraint_enju_leaf_rc10.rb +1 -1
  197. data/spec/dummy/db/migrate/20140614065404_create_resource_export_files.rb +1 -1
  198. data/spec/dummy/db/migrate/20140614141500_create_resource_export_file_transitions.rb +1 -1
  199. data/spec/dummy/db/migrate/20140628072217_add_user_encoding_to_user_import_file.rb +1 -1
  200. data/spec/dummy/db/migrate/20140628073524_add_user_encoding_to_agent_import_file.rb +1 -1
  201. data/spec/dummy/db/migrate/20140628073535_add_user_encoding_to_resource_import_file.rb +1 -1
  202. data/spec/dummy/db/migrate/20140709113413_create_user_export_files.rb +1 -1
  203. data/spec/dummy/db/migrate/20140709113905_create_user_export_file_transitions.rb +2 -6
  204. data/spec/dummy/db/migrate/20140720140916_add_binding_item_identifier_to_item.rb +1 -1
  205. data/spec/dummy/db/migrate/20140720170714_add_default_library_id_to_user_import_file.rb +1 -1
  206. data/spec/dummy/db/migrate/20140720170735_add_default_user_group_id_to_user_import_file.rb +1 -1
  207. data/spec/dummy/db/migrate/20140721151416_add_default_shelf_id_to_resource_import_file.rb +1 -1
  208. data/spec/dummy/db/migrate/20140802082007_add_manifestation_id_to_item.rb +1 -1
  209. data/spec/dummy/db/migrate/20140811031145_add_expired_at_to_profile.rb +1 -1
  210. data/spec/dummy/db/migrate/20140813182425_add_publication_place_to_manifestation.rb +1 -1
  211. data/spec/dummy/db/migrate/20140821151023_create_colors.rb +1 -1
  212. data/spec/dummy/db/migrate/20140822114527_add_error_message_to_resource_import_result.rb +1 -1
  213. data/spec/dummy/db/migrate/20140823083524_add_extent_to_manifestation.rb +1 -1
  214. data/spec/dummy/db/migrate/20140823094847_add_dimensions_to_manifestation.rb +1 -1
  215. data/spec/dummy/db/migrate/20140823095740_rename_manifestation_periodical_to_serial.rb +1 -1
  216. data/spec/dummy/db/migrate/20141003181336_add_full_name_transcription_to_profile.rb +1 -1
  217. data/spec/dummy/db/migrate/20141003182825_add_date_of_birth_to_profile.rb +1 -1
  218. data/spec/dummy/db/migrate/20150117111136_add_foreign_key_to_items_referencing_manifestations.rb +1 -1
  219. data/spec/dummy/db/migrate/20150221063719_add_settings_to_library_group.rb +1 -1
  220. data/spec/dummy/db/migrate/20150506105356_add_error_message_to_user_import_result.rb +1 -1
  221. data/spec/dummy/db/migrate/20150924115059_create_withdraws.rb +1 -1
  222. data/spec/dummy/db/migrate/20151125004028_add_profile_id_to_agent.rb +1 -1
  223. data/spec/dummy/db/migrate/20160319144230_create_issn_records.rb +11 -0
  224. data/spec/dummy/db/migrate/20160506144040_create_isbn_records.rb +11 -0
  225. data/spec/dummy/db/migrate/20160610093229_add_html_snippet_to_library_group.rb +1 -1
  226. data/spec/dummy/db/migrate/20160627232219_add_most_recent_to_user_import_file_transitions.rb +1 -1
  227. data/spec/dummy/db/migrate/20160627232316_add_most_recent_to_user_export_file_transitions.rb +1 -1
  228. data/spec/dummy/db/migrate/20160801080612_add_most_recent_to_import_request_transitions.rb +1 -1
  229. data/spec/dummy/db/migrate/20160801080619_add_most_recent_to_resource_import_file_transitions.rb +1 -1
  230. data/spec/dummy/db/migrate/20160801080637_add_most_recent_to_resource_export_file_transitions.rb +1 -1
  231. data/spec/dummy/db/migrate/20160801080643_add_most_recent_to_agent_import_file_transitions.rb +1 -1
  232. data/spec/dummy/db/migrate/20160811102604_add_picture_width_to_picture_file.rb +1 -1
  233. data/spec/dummy/db/migrate/20160813191647_add_max_number_of_results_to_library_group.rb +1 -1
  234. data/spec/dummy/db/migrate/20160813191733_add_family_name_first_to_library_group.rb +1 -1
  235. data/spec/dummy/db/migrate/20160813192542_add_pub_year_facet_range_interval_to_library_group.rb +1 -1
  236. data/spec/dummy/db/migrate/20160813203039_add_user_id_to_library_group.rb +1 -1
  237. data/spec/dummy/db/migrate/20160820004638_add_attachment_attachment_to_carrier_types.rb +1 -1
  238. data/spec/dummy/db/migrate/20170116134107_create_issn_record_and_manifestations.rb +11 -0
  239. data/spec/dummy/db/migrate/20170116134120_create_isbn_record_and_manifestations.rb +11 -0
  240. data/spec/dummy/db/migrate/20170305064014_add_csv_charset_conversion_to_library_group.rb +1 -1
  241. data/spec/dummy/db/migrate/20171014084528_add_header_logo_to_library_group.rb +1 -1
  242. data/spec/dummy/db/migrate/20171119051258_set_not_null_to_manifestation_id_on_items.rb +1 -1
  243. data/spec/dummy/db/migrate/20171126133835_rename_login_banner_to_old_login_banner.rb +1 -1
  244. data/spec/dummy/db/migrate/20171126135238_add_foreign_key_to_library_group_id_on_library.rb +1 -1
  245. data/spec/dummy/db/migrate/20180102162311_add_header_logo_meta_to_library_group.rb +1 -1
  246. data/spec/dummy/db/migrate/20180107160726_add_constraints_to_most_recent_for_user_import_file_transitions.rb +1 -1
  247. data/spec/dummy/db/migrate/20180107160740_add_constraints_to_most_recent_for_user_export_file_transitions.rb +1 -1
  248. data/spec/dummy/db/migrate/20180107161311_add_constraints_to_most_recent_for_agent_import_file_transitions.rb +1 -1
  249. data/spec/dummy/db/migrate/20180107161331_add_constraints_to_most_recent_for_resource_import_file_transitions.rb +1 -1
  250. data/spec/dummy/db/migrate/20180107161347_add_constraints_to_most_recent_for_resource_export_file_transitions.rb +1 -1
  251. data/spec/dummy/db/migrate/20180107161410_add_constraints_to_most_recent_for_import_request_transitions.rb +1 -1
  252. data/spec/dummy/db/migrate/20190102034126_create_doi_records.rb +13 -0
  253. data/spec/dummy/db/migrate/20190311154610_create_periodicals.rb +10 -0
  254. data/spec/dummy/db/migrate/20190312033839_create_periodical_and_manifestations.rb +11 -0
  255. data/spec/dummy/db/migrate/20191216131755_add_email_to_library_group.rb +6 -0
  256. data/spec/dummy/db/migrate/20191219122214_create_custom_properties.rb +12 -0
  257. data/spec/dummy/db/schema.rb +435 -354
  258. data/spec/dummy/private/system/carrier_types/attachments/000/000/001/original/book.png +0 -0
  259. data/spec/dummy/private/system/carrier_types/attachments/000/000/001/thumb/book.png +0 -0
  260. data/spec/dummy/private/system/resource_export_files/resource_exports/000/000/001/original/data +151 -0
  261. data/spec/dummy/private/system/resource_export_files/resource_exports/000/000/002/original/data +151 -0
  262. data/spec/dummy/private/system/resource_export_files/resource_exports/000/000/003/original/data +151 -0
  263. data/spec/dummy/private/system/user_import_files/user_imports/000/000/001/original/user_import_file_sample.tsv +10 -0
  264. data/spec/dummy/private/system/user_import_files/user_imports/000/000/002/original/user_delete_file.tsv +4 -0
  265. data/spec/dummy/private/system/user_import_files/user_imports/000/000/003/original/user_import_file_sample.tsv +10 -0
  266. data/spec/dummy/private/system/user_import_files/user_imports/000/000/004/original/user_delete_file.tsv +4 -0
  267. data/spec/dummy/private/system/user_import_files/user_imports/000/000/005/original/user_import_file_sample.tsv +10 -0
  268. data/spec/dummy/private/system/user_import_files/user_imports/000/000/006/original/user_delete_file.tsv +4 -0
  269. data/spec/dummy/private/system/user_import_files/user_imports/000/000/007/original/user_import_file_sample.tsv +10 -0
  270. data/spec/dummy/private/system/user_import_files/user_imports/000/000/008/original/user_delete_file.tsv +4 -0
  271. data/spec/dummy/private/system/user_import_files/user_imports/000/000/009/original/user_import_file_sample.tsv +10 -0
  272. data/spec/dummy/private/system/user_import_files/user_imports/000/000/010/original/user_delete_file.tsv +4 -0
  273. data/spec/dummy/private/system/user_import_files/user_imports/000/000/011/original/user_import_file_sample.tsv +10 -0
  274. data/spec/dummy/private/system/user_import_files/user_imports/000/000/012/original/user_delete_file.tsv +4 -0
  275. data/spec/factories/item.rb +3 -3
  276. data/spec/factories/reserve.rb +5 -1
  277. data/spec/fixtures/bookstores.yml +99 -0
  278. data/spec/fixtures/budget_types.yml +30 -0
  279. data/spec/fixtures/carrier_type_has_checkout_types.yml +5 -5
  280. data/spec/fixtures/checked_items.yml +7 -7
  281. data/spec/fixtures/checkins.yml +7 -7
  282. data/spec/fixtures/checkout_stat_has_manifestations.yml +5 -5
  283. data/spec/fixtures/checkout_stat_has_users.yml +5 -5
  284. data/spec/fixtures/checkout_types.yml +3 -3
  285. data/spec/fixtures/checkouts.yml +10 -10
  286. data/spec/fixtures/circulation_statuses.yml +3 -3
  287. data/spec/fixtures/demands.yml +4 -4
  288. data/spec/fixtures/events.yml +0 -9
  289. data/spec/fixtures/item_has_use_restrictions.yml +5 -5
  290. data/spec/fixtures/library_groups.yml +6 -11
  291. data/spec/fixtures/manifestation_checkout_stats.yml +4 -4
  292. data/spec/fixtures/manifestation_reserve_stats.yml +4 -4
  293. data/spec/fixtures/reserve_stat_has_manifestations.yml +5 -5
  294. data/spec/fixtures/reserve_stat_has_users.yml +5 -5
  295. data/spec/fixtures/reserve_transitions.yml +3 -3
  296. data/spec/fixtures/reserves.yml +7 -8
  297. data/spec/fixtures/use_restrictions.yml +3 -3
  298. data/spec/fixtures/user_checkout_stats.yml +4 -4
  299. data/spec/fixtures/user_group_has_checkout_types.yml +5 -5
  300. data/spec/fixtures/user_reserve_stats.yml +4 -4
  301. data/spec/models/carrier_type_has_checkout_type_spec.rb +5 -5
  302. data/spec/models/checked_item_spec.rb +7 -7
  303. data/spec/models/checkin_spec.rb +7 -7
  304. data/spec/models/checkout_spec.rb +10 -10
  305. data/spec/models/checkout_stat_has_manifestation_spec.rb +5 -5
  306. data/spec/models/checkout_stat_has_user_spec.rb +5 -5
  307. data/spec/models/checkout_type_spec.rb +3 -3
  308. data/spec/models/circulation_status_spec.rb +3 -3
  309. data/spec/models/manifestation_checkout_stat_spec.rb +4 -4
  310. data/spec/models/manifestation_reserve_stat_spec.rb +4 -4
  311. data/spec/models/manifestation_spec.rb +2 -2
  312. data/spec/models/reserve_spec.rb +7 -8
  313. data/spec/models/reserve_stat_has_manifestation_spec.rb +5 -5
  314. data/spec/models/reserve_stat_has_user_spec.rb +5 -5
  315. data/spec/models/user_checkout_stat_spec.rb +4 -4
  316. data/spec/models/user_group_has_checkout_type_spec.rb +5 -5
  317. data/spec/models/user_import_file_spec.rb +1 -1
  318. data/spec/models/user_reserve_stat_spec.rb +4 -4
  319. data/spec/models/withdraw_spec.rb +6 -4
  320. data/spec/policies/manifestation_policy_spec.rb +1 -2
  321. data/spec/rails_helper.rb +1 -4
  322. data/spec/system/items_spec.rb +21 -0
  323. metadata +72 -30
  324. data/spec/dummy/db/test.sqlite3 +0 -0
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 516387cbac4a70663f83ded054892637bf98e5f6d64233017821acced1942296
4
- data.tar.gz: 90e73348c2f3293cf0d418733fed3215545dd528b6f3147a3a6ba6274260c0bb
3
+ metadata.gz: d8fcd1cfe77ab4212272e640bb1adb78422a1dcd3aa3dd7d44a6a028fd5f140c
4
+ data.tar.gz: 81bfde2ee1205d7a8a3f892cf4dfd98d88106fbd5a55f98ab0dfe226af66594b
5
5
  SHA512:
6
- metadata.gz: 04f9013ee9f47db46c91f466e6cbf780e64b1ff9a24a867aab041d0dd983efe12e7c19dae88834e9a157c6511f05e9b0973d0b8b15a0f1f466c506aef062c0f9
7
- data.tar.gz: 91d41e5eeba412df21206023bb4bb95911decf8cb40503b0887b0a581180c6b27e9f68bd16ea5f8a3c4e03875fff91402b540c1b10e9f85772c35e70e5b10760
6
+ metadata.gz: a43d1848806014026e757b3d531c975bb16eb716d7af4bc660e14bf8bc74852d659c1995c9bdd9ac7dae79c938bb78bb70deb5a53f99f8f6926d6b75e2ba4eb0
7
+ data.tar.gz: 26d59d22ec2a036b9ee43e2917275900f5b71848272c9ae33874f721fda32620e8b70fe9aa781b304d0cd5f0b51e00d4706fcda78ef63faf2f5699b25626c45f
data/README.md CHANGED
@@ -1,5 +1,5 @@
1
1
  # EnjuCirculation
2
- ![](https://github.com/next-l/enju_circulation/workflows/Ruby/badge.svg?branch=2.x)
2
+ [![CircleCI](https://circleci.com/gh/next-l/enju_circulation/tree/2.x.svg?style=svg)](https://circleci.com/gh/next-l/enju_circulation/tree/2.x)
3
3
  [![Coverage Status](https://coveralls.io/repos/github/next-l/enju_circulation/badge.svg?branch=2.x)](https://coveralls.io/github/next-l/enju_circulation?branch=2.x)
4
4
 
5
5
  This project rocks and uses MIT-LICENSE.
@@ -16,11 +16,11 @@ end
16
16
  #
17
17
  # Table name: carrier_type_has_checkout_types
18
18
  #
19
- # id :integer not null, primary key
20
- # carrier_type_id :integer not null
21
- # checkout_type_id :integer not null
19
+ # id :bigint not null, primary key
20
+ # carrier_type_id :bigint not null
21
+ # checkout_type_id :bigint not null
22
22
  # note :text
23
23
  # position :integer
24
- # created_at :datetime
25
- # updated_at :datetime
24
+ # created_at :datetime not null
25
+ # updated_at :datetime not null
26
26
  #
@@ -116,12 +116,12 @@ end
116
116
  #
117
117
  # Table name: checked_items
118
118
  #
119
- # id :integer not null, primary key
120
- # item_id :integer not null
121
- # basket_id :integer not null
122
- # librarian_id :integer
119
+ # id :bigint not null, primary key
120
+ # item_id :bigint not null
121
+ # basket_id :bigint not null
122
+ # librarian_id :bigint
123
123
  # due_date :datetime not null
124
- # created_at :datetime
125
- # updated_at :datetime
126
- # user_id :integer
124
+ # created_at :datetime not null
125
+ # updated_at :datetime not null
126
+ # user_id :bigint
127
127
  #
@@ -85,12 +85,12 @@ end
85
85
  #
86
86
  # Table name: checkins
87
87
  #
88
- # id :integer not null, primary key
89
- # item_id :integer not null
90
- # librarian_id :integer
91
- # basket_id :integer
92
- # created_at :datetime
93
- # updated_at :datetime
88
+ # id :bigint not null, primary key
89
+ # item_id :bigint not null
90
+ # librarian_id :bigint
91
+ # basket_id :bigint
92
+ # created_at :datetime not null
93
+ # updated_at :datetime not null
94
94
  # lock_version :integer default(0), not null
95
- # checkin_id :bigint
95
+ # checkout_id :bigint
96
96
  #
@@ -167,17 +167,17 @@ end
167
167
  #
168
168
  # Table name: checkouts
169
169
  #
170
- # id :integer not null, primary key
171
- # user_id :integer
172
- # item_id :integer not null
173
- # checkin_id :integer
174
- # librarian_id :integer
175
- # basket_id :integer
170
+ # id :bigint not null, primary key
171
+ # user_id :bigint
172
+ # item_id :bigint not null
173
+ # checkin_id :bigint
174
+ # librarian_id :bigint
175
+ # basket_id :bigint
176
176
  # due_date :datetime
177
177
  # checkout_renewal_count :integer default(0), not null
178
178
  # lock_version :integer default(0), not null
179
- # created_at :datetime
180
- # updated_at :datetime
181
- # shelf_id :integer
182
- # library_id :integer
179
+ # created_at :datetime not null
180
+ # updated_at :datetime not null
181
+ # shelf_id :bigint
182
+ # library_id :bigint
183
183
  #
@@ -14,10 +14,10 @@ end
14
14
  #
15
15
  # Table name: checkout_stat_has_manifestations
16
16
  #
17
- # id :integer not null, primary key
18
- # manifestation_checkout_stat_id :integer not null
19
- # manifestation_id :integer not null
17
+ # id :bigint not null, primary key
18
+ # manifestation_checkout_stat_id :bigint not null
19
+ # manifestation_id :bigint not null
20
20
  # checkouts_count :integer
21
- # created_at :datetime
22
- # updated_at :datetime
21
+ # created_at :datetime not null
22
+ # updated_at :datetime not null
23
23
  #
@@ -14,10 +14,10 @@ end
14
14
  #
15
15
  # Table name: checkout_stat_has_users
16
16
  #
17
- # id :integer not null, primary key
18
- # user_checkout_stat_id :integer not null
19
- # user_id :integer not null
17
+ # id :bigint not null, primary key
18
+ # user_checkout_stat_id :bigint not null
19
+ # user_id :bigint not null
20
20
  # checkouts_count :integer default(0), not null
21
- # created_at :datetime
22
- # updated_at :datetime
21
+ # created_at :datetime not null
22
+ # updated_at :datetime not null
23
23
  #
@@ -19,12 +19,12 @@ end
19
19
  #
20
20
  # Table name: checkout_types
21
21
  #
22
- # id :integer not null, primary key
22
+ # id :bigint not null, primary key
23
23
  # name :string not null
24
24
  # display_name :text
25
25
  # note :text
26
26
  # position :integer
27
- # created_at :datetime
28
- # updated_at :datetime
27
+ # created_at :datetime not null
28
+ # updated_at :datetime not null
29
29
  # display_name_translations :jsonb not null
30
30
  #
@@ -17,12 +17,12 @@ end
17
17
  #
18
18
  # Table name: circulation_statuses
19
19
  #
20
- # id :integer not null, primary key
20
+ # id :bigint not null, primary key
21
21
  # name :string not null
22
22
  # display_name :text
23
23
  # note :text
24
24
  # position :integer
25
- # created_at :datetime
26
- # updated_at :datetime
25
+ # created_at :datetime not null
26
+ # updated_at :datetime not null
27
27
  # display_name_translations :jsonb not null
28
28
  #
@@ -35,12 +35,13 @@ module EnjuCirculation
35
35
  has_many :reserves
36
36
  has_many :checked_items
37
37
  has_many :baskets, through: :checked_items
38
- belongs_to :circulation_status, validate: true
38
+ belongs_to :circulation_status
39
39
  belongs_to :checkout_type
40
40
  has_one :item_has_use_restriction, dependent: :destroy
41
41
  has_one :use_restriction, through: :item_has_use_restriction
42
- validates_associated :circulation_status, :checkout_type
43
42
  validates :circulation_status, :checkout_type, presence: true
43
+ validate :check_circulation_status
44
+
44
45
  searchable do
45
46
  string :circulation_status do
46
47
  circulation_status.name
@@ -53,6 +54,14 @@ module EnjuCirculation
53
54
  self.circulation_status = CirculationStatus.find_by(name: 'In Process') if circulation_status.nil?
54
55
  end
55
56
 
57
+ def check_circulation_status
58
+ #circulation_status.name_will_change!
59
+ #return unless circulation_status.name_change.first == 'Removed'
60
+ return unless circulation_status.name == 'Removed'
61
+ errors[:base] << I18n.t('activerecord.errors.models.item.attributes.circulation_status_id.is_rented') if rented?
62
+ errors[:base] << I18n.t('activerecord.errors.models.item.attributes.circulation_status_id.is_reserved') if reserved?
63
+ end
64
+
56
65
  def checkout_status(user)
57
66
  return nil unless user
58
67
  user.profile.user_group.user_group_has_checkout_types.find_by(checkout_type_id: checkout_type.id)
@@ -68,6 +77,10 @@ module EnjuCirculation
68
77
  false
69
78
  end
70
79
 
80
+ def rented?
81
+ rent?
82
+ end
83
+
71
84
  def reserved_by_user?(user)
72
85
  if manifestation.next_reservation
73
86
  return true if manifestation.next_reservation.user == user
@@ -3,7 +3,8 @@ module EnjuCirculation
3
3
  extend ActiveSupport::Concern
4
4
 
5
5
  included do
6
- before_save :withdraw!, on: :create
6
+ before_create :withdraw!
7
+ validate :check_item
7
8
  end
8
9
 
9
10
  def withdraw!
@@ -12,5 +13,10 @@ module EnjuCirculation
12
13
  item.use_restriction = UseRestriction.where(name: 'Not For Loan').first
13
14
  item.index!
14
15
  end
16
+
17
+ def check_item
18
+ errors.add(:item_id, :is_rented) if item.try(:rent?)
19
+ errors.add(:item_id, :is_reserved) if item.try(:reserved?)
20
+ end
15
21
  end
16
22
  end
data/app/models/demand.rb CHANGED
@@ -8,10 +8,10 @@ end
8
8
  #
9
9
  # Table name: demands
10
10
  #
11
- # id :integer not null, primary key
12
- # user_id :integer
13
- # item_id :integer
14
- # message_id :integer
11
+ # id :bigint not null, primary key
12
+ # user_id :bigint
13
+ # item_id :bigint
14
+ # message_id :bigint
15
15
  # created_at :datetime not null
16
16
  # updated_at :datetime not null
17
17
  #
@@ -14,9 +14,9 @@ end
14
14
  #
15
15
  # Table name: item_has_use_restrictions
16
16
  #
17
- # id :integer not null, primary key
18
- # item_id :integer not null
19
- # use_restriction_id :integer not null
20
- # created_at :datetime
21
- # updated_at :datetime
17
+ # id :bigint not null, primary key
18
+ # item_id :bigint not null
19
+ # use_restriction_id :bigint not null
20
+ # created_at :datetime not null
21
+ # updated_at :datetime not null
22
22
  #
@@ -39,29 +39,19 @@ class ManifestationCheckoutStat < ApplicationRecord
39
39
  transition_to!(:completed)
40
40
  send_message
41
41
  end
42
-
43
- private
44
-
45
- def self.transition_class
46
- ManifestationCheckoutStatTransition
47
- end
48
-
49
- def self.initial_state
50
- :pending
51
- end
52
42
  end
53
43
 
54
44
  # == Schema Information
55
45
  #
56
46
  # Table name: manifestation_checkout_stats
57
47
  #
58
- # id :integer not null, primary key
48
+ # id :bigint not null, primary key
59
49
  # start_date :datetime
60
50
  # end_date :datetime
61
51
  # note :text
62
- # created_at :datetime
63
- # updated_at :datetime
52
+ # created_at :datetime not null
53
+ # updated_at :datetime not null
64
54
  # started_at :datetime
65
55
  # completed_at :datetime
66
- # user_id :integer
56
+ # user_id :bigint
67
57
  #
@@ -10,12 +10,12 @@ end
10
10
  #
11
11
  # Table name: manifestation_checkout_stat_transitions
12
12
  #
13
- # id :integer not null, primary key
13
+ # id :bigint not null, primary key
14
14
  # to_state :string
15
15
  # metadata :text default({})
16
16
  # sort_key :integer
17
17
  # manifestation_checkout_stat_id :integer
18
- # created_at :datetime
19
- # updated_at :datetime
18
+ # created_at :datetime not null
19
+ # updated_at :datetime not null
20
20
  # most_recent :boolean not null
21
21
  #
@@ -39,29 +39,19 @@ class ManifestationReserveStat < ApplicationRecord
39
39
  transition_to!(:completed)
40
40
  send_message
41
41
  end
42
-
43
- private
44
-
45
- def self.transition_class
46
- ManifestationReserveStatTransition
47
- end
48
-
49
- def self.initial_state
50
- :pending
51
- end
52
42
  end
53
43
 
54
44
  # == Schema Information
55
45
  #
56
46
  # Table name: manifestation_reserve_stats
57
47
  #
58
- # id :integer not null, primary key
48
+ # id :bigint not null, primary key
59
49
  # start_date :datetime
60
50
  # end_date :datetime
61
51
  # note :text
62
- # created_at :datetime
63
- # updated_at :datetime
52
+ # created_at :datetime not null
53
+ # updated_at :datetime not null
64
54
  # started_at :datetime
65
55
  # completed_at :datetime
66
- # user_id :integer
56
+ # user_id :bigint
67
57
  #
@@ -10,12 +10,12 @@ end
10
10
  #
11
11
  # Table name: manifestation_reserve_stat_transitions
12
12
  #
13
- # id :integer not null, primary key
13
+ # id :bigint not null, primary key
14
14
  # to_state :string
15
15
  # metadata :text default({})
16
16
  # sort_key :integer
17
17
  # manifestation_reserve_stat_id :integer
18
- # created_at :datetime
19
- # updated_at :datetime
18
+ # created_at :datetime not null
19
+ # updated_at :datetime not null
20
20
  # most_recent :boolean not null
21
21
  #
@@ -374,7 +374,7 @@ class Reserve < ApplicationRecord
374
374
  end
375
375
 
376
376
  def manifestation_must_include_item
377
- if item_id.present? && !completed?
377
+ if manifestation && item && !completed?
378
378
  errors[:base] << I18n.t('reserve.invalid_item') unless manifestation.items.include?(item)
379
379
  end
380
380
  end
@@ -382,31 +382,22 @@ class Reserve < ApplicationRecord
382
382
  if defined?(EnjuInterLibraryLoan)
383
383
  has_one :inter_library_loan
384
384
  end
385
-
386
- def self.transition_class
387
- ReserveTransition
388
- end
389
-
390
- def self.initial_state
391
- :pending
392
- end
393
385
  end
394
386
 
395
387
  # == Schema Information
396
388
  #
397
389
  # Table name: reserves
398
390
  #
399
- # id :integer not null, primary key
400
- # user_id :integer not null
401
- # manifestation_id :integer not null
402
- # item_id :integer
403
- # request_status_type_id :integer not null
391
+ # id :bigint not null, primary key
392
+ # user_id :bigint not null
393
+ # manifestation_id :bigint not null
394
+ # item_id :bigint
395
+ # request_status_type_id :bigint not null
404
396
  # checked_out_at :datetime
405
- # created_at :datetime
406
- # updated_at :datetime
397
+ # created_at :datetime not null
398
+ # updated_at :datetime not null
407
399
  # canceled_at :datetime
408
400
  # expired_at :datetime
409
- # deleted_at :datetime
410
401
  # expiration_notice_to_patron :boolean default(FALSE)
411
402
  # expiration_notice_to_library :boolean default(FALSE)
412
403
  # pickup_location_id :integer
@@ -12,10 +12,10 @@ end
12
12
  #
13
13
  # Table name: reserve_stat_has_manifestations
14
14
  #
15
- # id :integer not null, primary key
16
- # manifestation_reserve_stat_id :integer not null
17
- # manifestation_id :integer not null
15
+ # id :bigint not null, primary key
16
+ # manifestation_reserve_stat_id :bigint not null
17
+ # manifestation_id :bigint not null
18
18
  # reserves_count :integer
19
- # created_at :datetime
20
- # updated_at :datetime
19
+ # created_at :datetime not null
20
+ # updated_at :datetime not null
21
21
  #
@@ -15,10 +15,10 @@ end
15
15
  #
16
16
  # Table name: reserve_stat_has_users
17
17
  #
18
- # id :integer not null, primary key
19
- # user_reserve_stat_id :integer not null
20
- # user_id :integer not null
18
+ # id :bigint not null, primary key
19
+ # user_reserve_stat_id :bigint not null
20
+ # user_id :bigint not null
21
21
  # reserves_count :integer
22
- # created_at :datetime
23
- # updated_at :datetime
22
+ # created_at :datetime not null
23
+ # updated_at :datetime not null
24
24
  #
@@ -10,12 +10,12 @@ end
10
10
  #
11
11
  # Table name: reserve_transitions
12
12
  #
13
- # id :integer not null, primary key
13
+ # id :bigint not null, primary key
14
14
  # to_state :string
15
15
  # metadata :text default({})
16
16
  # sort_key :integer
17
17
  # reserve_id :integer
18
- # created_at :datetime
19
- # updated_at :datetime
18
+ # created_at :datetime not null
19
+ # updated_at :datetime not null
20
20
  # most_recent :boolean not null
21
21
  #
@@ -18,12 +18,12 @@ end
18
18
  #
19
19
  # Table name: use_restrictions
20
20
  #
21
- # id :integer not null, primary key
21
+ # id :bigint not null, primary key
22
22
  # name :string not null
23
23
  # display_name :text
24
24
  # note :text
25
25
  # position :integer
26
- # created_at :datetime
27
- # updated_at :datetime
26
+ # created_at :datetime not null
27
+ # updated_at :datetime not null
28
28
  # display_name_translations :jsonb not null
29
29
  #
@@ -38,29 +38,19 @@ class UserCheckoutStat < ApplicationRecord
38
38
  transition_to!(:completed)
39
39
  send_message
40
40
  end
41
-
42
- private
43
-
44
- def self.transition_class
45
- UserCheckoutStatTransition
46
- end
47
-
48
- def self.initial_state
49
- :pending
50
- end
51
41
  end
52
42
 
53
43
  # == Schema Information
54
44
  #
55
45
  # Table name: user_checkout_stats
56
46
  #
57
- # id :integer not null, primary key
47
+ # id :bigint not null, primary key
58
48
  # start_date :datetime
59
49
  # end_date :datetime
60
50
  # note :text
61
- # created_at :datetime
62
- # updated_at :datetime
51
+ # created_at :datetime not null
52
+ # updated_at :datetime not null
63
53
  # started_at :datetime
64
54
  # completed_at :datetime
65
- # user_id :integer
55
+ # user_id :bigint
66
56
  #
@@ -10,12 +10,12 @@ end
10
10
  #
11
11
  # Table name: user_checkout_stat_transitions
12
12
  #
13
- # id :integer not null, primary key
13
+ # id :bigint not null, primary key
14
14
  # to_state :string
15
15
  # metadata :text default({})
16
16
  # sort_key :integer
17
17
  # user_checkout_stat_id :integer
18
- # created_at :datetime
19
- # updated_at :datetime
18
+ # created_at :datetime not null
19
+ # updated_at :datetime not null
20
20
  # most_recent :boolean not null
21
21
  #
@@ -46,9 +46,9 @@ end
46
46
  #
47
47
  # Table name: user_group_has_checkout_types
48
48
  #
49
- # id :integer not null, primary key
50
- # user_group_id :integer not null
51
- # checkout_type_id :integer not null
49
+ # id :bigint not null, primary key
50
+ # user_group_id :bigint not null
51
+ # checkout_type_id :bigint not null
52
52
  # checkout_limit :integer default(0), not null
53
53
  # checkout_period :integer default(0), not null
54
54
  # checkout_renewal_limit :integer default(0), not null
@@ -58,7 +58,7 @@ end
58
58
  # fixed_due_date :datetime
59
59
  # note :text
60
60
  # position :integer
61
- # created_at :datetime
62
- # updated_at :datetime
61
+ # created_at :datetime not null
62
+ # updated_at :datetime not null
63
63
  # current_checkout_count :integer
64
64
  #
@@ -38,29 +38,19 @@ class UserReserveStat < ApplicationRecord
38
38
  transition_to!(:completed)
39
39
  send_message
40
40
  end
41
-
42
- private
43
-
44
- def self.transition_class
45
- UserReserveStatTransition
46
- end
47
-
48
- def self.initial_state
49
- :pending
50
- end
51
41
  end
52
42
 
53
43
  # == Schema Information
54
44
  #
55
45
  # Table name: user_reserve_stats
56
46
  #
57
- # id :integer not null, primary key
47
+ # id :bigint not null, primary key
58
48
  # start_date :datetime
59
49
  # end_date :datetime
60
50
  # note :text
61
- # created_at :datetime
62
- # updated_at :datetime
51
+ # created_at :datetime not null
52
+ # updated_at :datetime not null
63
53
  # started_at :datetime
64
54
  # completed_at :datetime
65
- # user_id :integer
55
+ # user_id :bigint
66
56
  #
@@ -10,12 +10,12 @@ end
10
10
  #
11
11
  # Table name: user_reserve_stat_transitions
12
12
  #
13
- # id :integer not null, primary key
13
+ # id :bigint not null, primary key
14
14
  # to_state :string
15
15
  # metadata :text default({})
16
16
  # sort_key :integer
17
17
  # user_reserve_stat_id :integer
18
- # created_at :datetime
19
- # updated_at :datetime
18
+ # created_at :datetime not null
19
+ # updated_at :datetime not null
20
20
  # most_recent :boolean not null
21
21
  #
@@ -11,11 +11,6 @@
11
11
  <%= f.label t('activerecord.models.basket') -%><br />
12
12
  <%= f.text_field :basket_id -%>
13
13
  </div>
14
-
15
- <div class="actions">
16
- <%= f.hidden_field :lock_version %>
17
- <%= f.submit %>
18
- </div>
19
14
  <%- end -%>
20
15
 
21
16
  <%= link_to t('page.show'), checked_item_path(@checked_item) -%> |
@@ -24,6 +24,13 @@
24
24
  <%= link_to checkout.shelf.display_name, checkout.shelf %>
25
25
  (<%= link_to checkout.shelf.library.display_name, checkout.shelf.library %>)
26
26
  <% end %>
27
+ <% if checkout.item.manifestation.next_reservation %>
28
+ <br />
29
+ (<%= link_to_if(current_user.has_role?('Librarian'),
30
+ t('page.number_of_reservations',
31
+ count: Reserve.waiting.where(manifestation_id: checkout.item.manifestation.id, checked_out_at: nil).count),
32
+ reserves_path(query: "manifestation_id_i:#{checkout.item.manifestation.id}")) -%>)
33
+ <% end %>
27
34
  </td>
28
35
  <td>
29
36
  <%= l(checkout.due_date, format: :only_date) -%>