enju_seed 0.3.0.beta.3 → 0.3.0.beta.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/controllers/my_accounts_controller.rb +34 -29
- data/app/models/concerns/enju_seed/enju_user.rb +0 -3
- data/app/views/my_accounts/_edit_credential.html.erb +99 -0
- data/app/views/my_accounts/_form.html.erb +24 -0
- data/app/views/my_accounts/_show.html.erb +1 -0
- data/app/views/my_accounts/edit.html.erb +32 -0
- data/app/views/my_accounts/show.html.erb +49 -0
- data/app/views/profiles/_edit_credential.html.erb +6 -6
- data/app/views/profiles/_edit_profile.html.erb +42 -0
- data/app/views/profiles/_form.html.erb +15 -0
- data/app/views/profiles/_show.html.erb +1 -0
- data/app/views/profiles/edit.html.erb +33 -0
- data/app/views/profiles/index.html.erb +70 -0
- data/app/views/profiles/new.html.erb +88 -0
- data/app/views/profiles/show.html+phone.erb +1 -0
- data/app/views/profiles/show.html.erb +67 -0
- data/app/views/roles/_form.html.erb +19 -0
- data/app/views/roles/edit.html.erb +13 -0
- data/app/views/roles/index.html.erb +32 -0
- data/app/views/roles/new.html.erb +12 -0
- data/app/views/roles/show.html.erb +46 -0
- data/db/migrate/20130221154434_add_additional_attributes_to_user.rb +1 -1
- data/lib/enju_seed/version.rb +1 -1
- data/spec/controllers/my_accounts_controller_spec.rb +3 -1
- data/spec/dummy/app/controllers/application_controller.rb +0 -1
- data/spec/dummy/db/migrate/001_create_agents.rb +1 -1
- data/spec/dummy/db/migrate/002_devise_create_users.rb +1 -1
- data/spec/dummy/db/migrate/032_create_checkins.rb +1 -1
- data/spec/dummy/db/migrate/033_create_checkouts.rb +1 -1
- data/spec/dummy/db/migrate/035_create_reserves.rb +1 -1
- data/spec/dummy/db/migrate/121_create_checked_items.rb +1 -1
- data/spec/dummy/db/migrate/125_create_donates.rb +1 -1
- data/spec/dummy/db/migrate/127_create_use_restrictions.rb +1 -1
- data/spec/dummy/db/migrate/129_create_item_has_use_restrictions.rb +1 -1
- data/spec/dummy/db/migrate/132_create_circulation_statuses.rb +1 -1
- data/spec/dummy/db/migrate/133_create_agent_merges.rb +1 -1
- data/spec/dummy/db/migrate/134_create_agent_merge_lists.rb +1 -1
- data/spec/dummy/db/migrate/20080830172106_create_exemplifies.rb +1 -1
- data/spec/dummy/db/migrate/20080905191442_create_agent_types.rb +1 -1
- data/spec/dummy/db/migrate/20081023092436_create_search_engines.rb +1 -1
- data/spec/dummy/db/migrate/20081025083323_create_countries.rb +1 -1
- data/spec/dummy/db/migrate/20081025083905_create_languages.rb +1 -1
- data/spec/dummy/db/migrate/20081027150907_create_picture_files.rb +1 -1
- data/spec/dummy/db/migrate/20081028083142_create_agent_import_files.rb +1 -1
- data/spec/dummy/db/migrate/20081028083208_create_resource_import_files.rb +1 -1
- data/spec/dummy/db/migrate/20081030023412_create_checkout_types.rb +1 -1
- data/spec/dummy/db/migrate/20081030023518_create_user_group_has_checkout_types.rb +1 -1
- data/spec/dummy/db/migrate/20081030023615_create_carrier_type_has_checkout_types.rb +1 -1
- data/spec/dummy/db/migrate/20081212075554_create_checkout_stat_has_manifestations.rb +1 -1
- data/spec/dummy/db/migrate/20081212080038_create_manifestation_checkout_stats.rb +1 -1
- data/spec/dummy/db/migrate/20081215094302_create_user_checkout_stats.rb +1 -1
- data/spec/dummy/db/migrate/20081215094955_create_checkout_stat_has_users.rb +1 -1
- data/spec/dummy/db/migrate/20081216190517_create_reserve_stat_has_manifestations.rb +1 -1
- data/spec/dummy/db/migrate/20081216190724_create_manifestation_reserve_stats.rb +1 -1
- data/spec/dummy/db/migrate/20081220023628_create_user_reserve_stats.rb +1 -1
- data/spec/dummy/db/migrate/20081220034117_create_reserve_stat_has_users.rb +1 -1
- data/spec/dummy/db/migrate/20090321130448_add_completed_at_to_user_checkout_stat.rb +1 -1
- data/spec/dummy/db/migrate/20090705133942_add_attachments_picture_to_picture_file.rb +1 -1
- data/spec/dummy/db/migrate/20090705212043_add_attachments_attachment_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20090812151902_create_agent_relationship_types.rb +1 -1
- data/spec/dummy/db/migrate/20090831220301_create_lending_policies.rb +1 -1
- data/spec/dummy/db/migrate/20091012101112_add_dcndl_schema.rb +1 -1
- data/spec/dummy/db/migrate/20091025080447_create_licenses.rb +1 -1
- data/spec/dummy/db/migrate/20091214131723_create_series_statements.rb +1 -1
- data/spec/dummy/db/migrate/20100211105551_add_admin_networks_to_library_group.rb +1 -1
- data/spec/dummy/db/migrate/20100223121519_rename_series_statement_title_to_original_title.rb +1 -1
- data/spec/dummy/db/migrate/20100314190054_add_opening_hour_to_library.rb +1 -1
- data/spec/dummy/db/migrate/20100321235924_add_series_statement_identifier_to_series_statement.rb +1 -1
- data/spec/dummy/db/migrate/20100606073747_create_agent_relationships.rb +1 -1
- data/spec/dummy/db/migrate/20100607044753_create_manifestation_relationship_types.rb +1 -1
- data/spec/dummy/db/migrate/20100814091104_add_position_to_agent_relationship.rb +1 -1
- data/spec/dummy/db/migrate/20100925043847_create_resource_import_results.rb +1 -1
- data/spec/dummy/db/migrate/20100925074559_create_agent_import_results.rb +1 -1
- data/spec/dummy/db/migrate/20101212070145_add_acquired_at_to_item.rb +1 -1
- data/spec/dummy/db/migrate/20110222073537_add_url_to_library_group.rb +1 -1
- data/spec/dummy/db/migrate/20110301035123_add_pub_date_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20110301121550_add_birth_date_and_death_date_to_agent.rb +1 -1
- data/spec/dummy/db/migrate/20110301134521_add_expire_date_to_reserve.rb +1 -1
- data/spec/dummy/db/migrate/20110318183304_add_valid_period_for_new_user_to_user_group.rb +1 -1
- data/spec/dummy/db/migrate/20110328130826_add_current_checkout_count_to_user_group_has_checkout_type.rb +1 -1
- data/spec/dummy/db/migrate/20110603184217_add_edit_mode_to_resource_import_file.rb +1 -1
- data/spec/dummy/db/migrate/20110619064807_add_edition_string_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20110620173525_add_bookstore_id_to_item.rb +1 -1
- data/spec/dummy/db/migrate/20110621093332_remove_expire_date_from_reserve.rb +1 -1
- data/spec/dummy/db/migrate/20110627034940_create_series_statement_merge_lists.rb +1 -1
- data/spec/dummy/db/migrate/20110627035057_create_series_statement_merges.rb +1 -1
- data/spec/dummy/db/migrate/20110627122938_add_number_of_day_to_notify_overdue_to_user_group.rb +1 -1
- data/spec/dummy/db/migrate/20110916091020_add_volume_number_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20110916103953_add_manifestaiton_id_to_series_statement.rb +1 -1
- data/spec/dummy/db/migrate/20110918162329_add_note_to_series_statement.rb +1 -1
- data/spec/dummy/db/migrate/20111124110059_create_create_types.rb +1 -1
- data/spec/dummy/db/migrate/20111124110319_create_realize_types.rb +1 -1
- data/spec/dummy/db/migrate/20111124110355_create_produce_types.rb +1 -1
- data/spec/dummy/db/migrate/20111124112131_add_create_type_to_create.rb +1 -1
- data/spec/dummy/db/migrate/20111129044509_add_pickup_location_to_reserve.rb +1 -1
- data/spec/dummy/db/migrate/20120105074911_add_isil_to_library.rb +1 -1
- data/spec/dummy/db/migrate/20120125152919_add_title_subseries_transcription_to_series_statement.rb +1 -1
- data/spec/dummy/db/migrate/20120129014038_create_budget_types.rb +1 -1
- data/spec/dummy/db/migrate/20120129020544_add_budget_type_id_to_item.rb +1 -1
- data/spec/dummy/db/migrate/20120319120638_add_content_type_id_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20120410104851_add_year_of_publication_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20120413072700_add_picture_meta_to_picture_file.rb +1 -1
- data/spec/dummy/db/migrate/20120413100352_add_fingerprint_to_picture_file.rb +1 -1
- data/spec/dummy/db/migrate/20120413161340_add_fingerprint_to_resource_import_file.rb +1 -1
- data/spec/dummy/db/migrate/20120413161403_add_fingerprint_to_agent_import_file.rb +1 -1
- data/spec/dummy/db/migrate/20120415164821_add_attachment_meta_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20120418081407_add_month_of_publication_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20120424103932_add_librarian_id_to_checked_item.rb +1 -1
- data/spec/dummy/db/migrate/20120510140958_add_closed_to_shelf.rb +1 -1
- data/spec/dummy/db/migrate/20120511072422_add_agent_identifier_to_agent.rb +1 -1
- data/spec/dummy/db/migrate/20120602141129_add_edit_mode_to_agent_import_file.rb +1 -1
- data/spec/dummy/db/migrate/20121116031206_add_fulltext_content_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20130303124821_add_retained_at_to_reserve.rb +1 -1
- data/spec/dummy/db/migrate/20130304015019_add_postponed_at_to_reserve.rb +1 -1
- data/spec/dummy/db/migrate/20130412083556_add_latitude_and_longitude_to_library.rb +1 -1
- data/spec/dummy/db/migrate/20130416054135_add_circulation_status_id_to_item.rb +1 -1
- data/spec/dummy/db/migrate/20130421093852_add_periodical_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20130421155019_add_creator_string_to_series_statement.rb +1 -1
- data/spec/dummy/db/migrate/20130421164124_add_series_master_to_series_statement.rb +1 -1
- data/spec/dummy/db/migrate/20130429020822_add_root_manifestation_id_to_series_statement.rb +1 -1
- data/spec/dummy/db/migrate/20130506175303_create_identifier_types.rb +1 -1
- data/spec/dummy/db/migrate/20130509185724_add_statement_of_responsibility_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20130519065638_add_lock_version_to_reserve.rb +1 -1
- data/spec/dummy/db/migrate/20130519065837_add_lock_version_to_checkin.rb +1 -1
- data/spec/dummy/db/migrate/20140110122216_create_user_import_files.rb +1 -1
- data/spec/dummy/db/migrate/20140110131010_create_user_import_results.rb +1 -1
- data/spec/dummy/db/migrate/20140518050147_create_reserve_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20140519170214_create_resource_import_file_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20140519171220_create_import_request_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20140524020735_create_agent_import_file_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20140524074813_create_user_import_file_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20140528045518_create_user_checkout_stat_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20140528045539_create_user_reserve_stat_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20140528045600_create_manifestation_checkout_stat_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20140528045617_create_manifestation_reserve_stat_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20140529014410_create_item_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20140614065404_create_resource_export_files.rb +1 -1
- data/spec/dummy/db/migrate/20140614141500_create_resource_export_file_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20140628072217_add_user_encoding_to_user_import_file.rb +1 -1
- data/spec/dummy/db/migrate/20140628073524_add_user_encoding_to_agent_import_file.rb +1 -1
- data/spec/dummy/db/migrate/20140628073535_add_user_encoding_to_resource_import_file.rb +1 -1
- data/spec/dummy/db/migrate/20140709113413_create_user_export_files.rb +1 -1
- data/spec/dummy/db/migrate/20140709113905_create_user_export_file_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20140720140916_add_binding_item_identifier_to_item.rb +1 -1
- data/spec/dummy/db/migrate/20140720170714_add_default_library_id_to_user_import_file.rb +1 -1
- data/spec/dummy/db/migrate/20140720170735_add_default_user_group_id_to_user_import_file.rb +1 -1
- data/spec/dummy/db/migrate/20140721151416_add_default_shelf_id_to_resource_import_file.rb +1 -1
- data/spec/dummy/db/migrate/20140810061942_add_user_id_to_user_checkout_stat.rb +1 -1
- data/spec/dummy/db/migrate/20140810091231_add_checkout_icalendar_token_to_profile.rb +1 -1
- data/spec/dummy/db/migrate/20140810091417_add_save_checkout_history_to_profile.rb +1 -1
- data/spec/dummy/db/migrate/20140813182425_add_publication_place_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20140821151023_create_colors.rb +1 -1
- data/spec/dummy/db/migrate/20140823083524_add_extent_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20140823094847_add_dimensions_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20140823095740_rename_manifestation_periodical_to_serial.rb +1 -1
- data/spec/dummy/db/migrate/20141014065831_add_shelf_id_to_checkout.rb +1 -1
- data/spec/dummy/db/migrate/20141020120523_add_library_id_to_checkout.rb +1 -1
- data/spec/dummy/db/migrate/20150106001709_create_demands.rb +1 -1
- data/spec/dummy/db/migrate/20150221063719_add_settings_to_library_group.rb +1 -1
- data/spec/dummy/db/migrate/20150302110310_add_attachment_id_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20150304183215_add_picture_id_to_picture_file.rb +1 -1
- data/spec/dummy/db/migrate/20150305025906_add_resource_import_id_to_resource_import_file.rb +1 -1
- data/spec/dummy/db/migrate/20150305030046_add_resource_export_id_to_resource_export_file.rb +1 -1
- data/spec/dummy/db/migrate/20150305031709_add_agent_import_id_to_agent_import_file.rb +1 -1
- data/spec/dummy/db/migrate/20150305105231_add_attachment_fingerprint_to_manifestation.rb +1 -1
- data/spec/dummy/db/migrate/20150420145354_add_attachment_to_carrier_type.rb +1 -1
- data/spec/dummy/db/migrate/20150420145420_add_attachment_to_content_type.rb +1 -1
- data/spec/dummy/db/migrate/20151125004028_add_profile_id_to_agent.rb +1 -1
- data/spec/dummy/db/migrate/20151213070943_add_translation_table_to_library_group.rb +1 -1
- data/spec/dummy/db/migrate/20160513000929_create_agent_names.rb +1 -1
- data/spec/dummy/db/migrate/20160610093229_add_html_snippet_to_library_group.rb +1 -1
- data/spec/dummy/db/migrate/20160627232219_add_most_recent_to_user_import_file_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20160627232316_add_most_recent_to_user_export_file_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20160703184619_add_most_recent_to_reserve_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20160703184650_add_most_recent_to_manifestation_checkout_stat_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20160703184723_add_most_recent_to_manifestation_reserve_stat_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20160703184747_add_most_recent_to_user_checkout_stat_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20160703184805_add_most_recent_to_user_reserve_stat_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20160801080612_add_most_recent_to_import_request_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20160801080619_add_most_recent_to_resource_import_file_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20160801080637_add_most_recent_to_resource_export_file_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20160801080643_add_most_recent_to_agent_import_file_transitions.rb +1 -1
- data/spec/dummy/db/migrate/20160813191533_add_book_jacket_source_to_library_group.rb +1 -1
- data/spec/dummy/db/migrate/20160813191647_add_max_number_of_results_to_library_group.rb +1 -1
- data/spec/dummy/db/migrate/20160813191733_add_family_name_first_to_library_group.rb +1 -1
- data/spec/dummy/db/migrate/20160813191820_add_screenshot_generator_to_library_group.rb +1 -1
- data/spec/dummy/db/migrate/20160813192542_add_pub_year_facet_range_interval_to_library_group.rb +1 -1
- data/spec/dummy/db/migrate/20160813203039_add_user_id_to_library_group.rb +1 -1
- data/spec/dummy/db/schema.rb +1250 -1317
- metadata +285 -289
- data/app/views/my_accounts/_edit_credential.html.slim +0 -63
- data/app/views/my_accounts/_form.html.slim +0 -20
- data/app/views/my_accounts/_show.html.slim +0 -1
- data/app/views/my_accounts/edit.html.slim +0 -30
- data/app/views/my_accounts/show.html+phone.slim +0 -1
- data/app/views/my_accounts/show.html.slim +0 -57
- data/app/views/profiles/_edit_credential.html.slim +0 -67
- data/app/views/profiles/_edit_profile.html.slim +0 -40
- data/app/views/profiles/_form.html.slim +0 -12
- data/app/views/profiles/_show.html.slim +0 -1
- data/app/views/profiles/edit.html.slim +0 -30
- data/app/views/profiles/index.html.slim +0 -61
- data/app/views/profiles/new.html.slim +0 -65
- data/app/views/profiles/show.html+phone.slim +0 -1
- data/app/views/profiles/show.html.slim +0 -67
- data/app/views/roles/_form.html.slim +0 -16
- data/app/views/roles/edit.html.slim +0 -15
- data/app/views/roles/index.html.slim +0 -27
- data/app/views/roles/new.html.slim +0 -13
- data/app/views/roles/show.html.slim +0 -46
- data/spec/dummy/db/migrate/149_create_message_templates.rb +0 -18
- data/spec/dummy/db/migrate/154_create_messages.rb +0 -23
- data/spec/dummy/db/migrate/20080819181903_create_message_requests.rb +0 -18
- data/spec/dummy/db/migrate/20110913115320_add_lft_and_rgt_to_message.rb +0 -11
- data/spec/dummy/db/migrate/20120125050502_add_depth_to_message.rb +0 -5
- data/spec/dummy/db/migrate/20120413170705_add_error_message_to_resource_import_file.rb +0 -5
- data/spec/dummy/db/migrate/20120413170720_add_error_message_to_agent_import_file.rb +0 -5
- data/spec/dummy/db/migrate/20140518111006_create_message_transitions.rb +0 -18
- data/spec/dummy/db/migrate/20140518135713_create_message_request_transitions.rb +0 -18
- data/spec/dummy/db/migrate/20140822114527_add_error_message_to_resource_import_result.rb +0 -5
- data/spec/dummy/db/migrate/20150506105356_add_error_message_to_user_import_result.rb +0 -5
- data/spec/dummy/db/migrate/20160703185015_add_most_recent_to_message_transitions.rb +0 -9
- data/spec/fixtures/message_requests.yml +0 -26
- data/spec/fixtures/message_templates.yml +0 -98
- data/spec/fixtures/messages.yml +0 -56
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 835e4e50f50c22127c0c9694c74ee201f394efaf
|
4
|
+
data.tar.gz: bed2b445b0888f024efa12157fbc2846f54c24e5
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 5b63fd1654b6eacdc3d3c3671fdd3034ad1a0008e746d3bff7c88b59f7c5b9d604627cbc856644abf4168ca15a3b96049d49f27f9c609260eced2af7290bc7fe
|
7
|
+
data.tar.gz: 96b40dcef213184a2d796af14f9d1d2497394c3ecbb6824230a0a31c76025c7df7fc323feb73fd3df7468c38f0f8acdce64144b6349b995e0913d540bcc8d389
|
@@ -15,35 +15,14 @@ class MyAccountsController < ApplicationController
|
|
15
15
|
end
|
16
16
|
|
17
17
|
def update
|
18
|
-
user_attrs = [
|
19
|
-
:id, :email, :current_password, :password, :password_confirmation
|
20
|
-
]
|
21
|
-
if current_user.has_role?('Administrator')
|
22
|
-
user_attrs += [
|
23
|
-
{ user_has_role_attributes: [:id, :role_id] }
|
24
|
-
]
|
25
|
-
end
|
26
|
-
|
27
|
-
user_params = ActionController::Parameters.new(params[:profile][:user_attributes]).permit(*user_attrs)
|
28
|
-
|
29
18
|
respond_to do |format|
|
30
|
-
|
31
|
-
@profile.assign_attributes(profile_params)
|
19
|
+
@profile.assign_attributes(profile_update_params)
|
32
20
|
|
33
|
-
if
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
format.json { head :no_content }
|
38
|
-
else
|
39
|
-
prepare_options
|
40
|
-
format.html { render action: 'edit' }
|
41
|
-
format.json { render json: current_user.errors, status: :unprocessable_entity }
|
42
|
-
end
|
21
|
+
if @profile.save
|
22
|
+
bypass_sign_in(current_user)
|
23
|
+
format.html { redirect_to my_account_url, notice: t('controller.successfully_updated', model: t('activerecord.models.user')) }
|
24
|
+
format.json { head :no_content }
|
43
25
|
else
|
44
|
-
current_user.errors.full_messages.each do |msg|
|
45
|
-
@profile.errors[:base] << msg
|
46
|
-
end
|
47
26
|
prepare_options
|
48
27
|
format.html { render action: 'edit' }
|
49
28
|
format.json { render json: current_user.errors, status: :unprocessable_entity }
|
@@ -69,17 +48,43 @@ class MyAccountsController < ApplicationController
|
|
69
48
|
|
70
49
|
def profile_params
|
71
50
|
attrs = [
|
72
|
-
:full_name, :full_name_transcription,
|
51
|
+
:full_name, :full_name_transcription,
|
73
52
|
:library_id, :keyword_list, :note,
|
74
|
-
:locale, :required_role_id,
|
53
|
+
:locale, :required_role_id,
|
75
54
|
:locked, :birth_date,
|
76
55
|
:save_checkout_history, :checkout_icalendar_token, # EnjuCirculation
|
77
|
-
:save_search_history # EnjuSearchLog
|
56
|
+
:save_search_history, { # EnjuSearchLog
|
57
|
+
user_attributes: [
|
58
|
+
:id, :username, :email, :locked,
|
59
|
+
{ user_has_role_attributes: [:id, :role_id] }
|
60
|
+
]
|
61
|
+
}
|
78
62
|
]
|
79
63
|
attrs << :user_group_id if current_user.has_role?('Librarian')
|
80
64
|
params.require(:profile).permit(*attrs)
|
81
65
|
end
|
82
66
|
|
67
|
+
def profile_update_params
|
68
|
+
attrs = [
|
69
|
+
:full_name, :full_name_transcription,
|
70
|
+
:keyword_list, :locale,
|
71
|
+
:save_checkout_history, :checkout_icalendar_token, # EnjuCirculation
|
72
|
+
:save_search_history, # EnjuSearchLog
|
73
|
+
]
|
74
|
+
if current_user.has_role?('Librarian')
|
75
|
+
attrs += [
|
76
|
+
:library_id, :expired_at, :birth_date,
|
77
|
+
:user_group_id, :required_role_id, :note, :user_number, {
|
78
|
+
user_attributes: [
|
79
|
+
:id, :email, :locked,
|
80
|
+
{ user_has_role_attributes: [:id, :role_id] }
|
81
|
+
]
|
82
|
+
}
|
83
|
+
]
|
84
|
+
end
|
85
|
+
params.require(:profile).permit(*attrs)
|
86
|
+
end
|
87
|
+
|
83
88
|
def prepare_options
|
84
89
|
@user_groups = UserGroup.order(:position)
|
85
90
|
@roles = Role.order(:position)
|
@@ -13,9 +13,6 @@ module EnjuSeed
|
|
13
13
|
has_one :user_has_role, dependent: :destroy
|
14
14
|
has_one :role, through: :user_has_role
|
15
15
|
belongs_to :profile
|
16
|
-
belongs_to :user_group
|
17
|
-
belongs_to :library
|
18
|
-
belongs_to :required_role, class_name: 'Role', foreign_key: 'required_role_id'
|
19
16
|
accepts_nested_attributes_for :user_has_role
|
20
17
|
|
21
18
|
validates :username, presence: true, uniqueness: true, format: {
|
@@ -0,0 +1,99 @@
|
|
1
|
+
<%= f.fields_for :user do |user_form| %>
|
2
|
+
<div id="left_pane_detail">
|
3
|
+
|
4
|
+
<div class="field">
|
5
|
+
<%= user_form.label :username -%><br />
|
6
|
+
<%= profile.user.username -%>
|
7
|
+
</div>
|
8
|
+
|
9
|
+
<div class="field">
|
10
|
+
<%= user_form.label :email -%><br />
|
11
|
+
<%= user_form.text_field :email %>
|
12
|
+
</div>
|
13
|
+
|
14
|
+
<% unless profile.user == current_user %>
|
15
|
+
<div class="field">
|
16
|
+
<%= user_form.label :auto_generated_password -%>
|
17
|
+
<%= user_form.check_box :auto_generated_password -%>
|
18
|
+
</div>
|
19
|
+
<% end %>
|
20
|
+
|
21
|
+
<div class="field">
|
22
|
+
<%= f.label :expired_at -%><br />
|
23
|
+
<%- if current_user.has_role?('Librarian') -%>
|
24
|
+
<%= f.text_field :expired_at, value: profile.expired_at.try(:strftime, "%Y-%m-%d"), class: 'date_text_field', placeholder: "#{t('page.example')}: 2011-04-12"-%>
|
25
|
+
<%- else -%>
|
26
|
+
<%= l(profile.expired_at) if profile.expired_at -%>
|
27
|
+
<%- end -%>
|
28
|
+
</div>
|
29
|
+
|
30
|
+
<div class="field">
|
31
|
+
<%= user_form.label :locked -%>
|
32
|
+
<%= user_form.check_box :locked, disabled: 'disabled' -%>
|
33
|
+
</div>
|
34
|
+
|
35
|
+
<div class="field">
|
36
|
+
<%= user_form.label t('activerecord.models.role') -%><br />
|
37
|
+
<%= user_form.fields_for :user_has_role do |u| %>
|
38
|
+
<%- if current_user.has_role?('Administrator') and current_user != profile.user -%>
|
39
|
+
<%= u.select :role_id, @roles.collect{|r| [r.display_name.localize, r.id]} %>
|
40
|
+
<% else %>
|
41
|
+
<%= current_user.role.display_name.localize -%>
|
42
|
+
<% end %>
|
43
|
+
<% end %>
|
44
|
+
</div>
|
45
|
+
</div>
|
46
|
+
|
47
|
+
<div id="right_pane_detail">
|
48
|
+
<div class="field">
|
49
|
+
<%= f.label :full_name -%><br />
|
50
|
+
<%= f.text_field :full_name -%>
|
51
|
+
</div>
|
52
|
+
|
53
|
+
<div class="field">
|
54
|
+
<%= f.label :full_name_transcription -%><br />
|
55
|
+
<%= f.text_field :full_name_transcription -%>
|
56
|
+
</div>
|
57
|
+
|
58
|
+
<div class="field">
|
59
|
+
<%= f.label t('activerecord.models.user_group') -%><br />
|
60
|
+
<%- if current_user.has_role?('Librarian') -%>
|
61
|
+
<%= f.select(:user_group_id, @user_groups.collect{|u| [u.display_name.localize, u.id]}) -%>
|
62
|
+
<%- else -%>
|
63
|
+
<%= current_user.profile.user_group.display_name.localize if current_user.profile.user_group -%>
|
64
|
+
<%- end -%>
|
65
|
+
</div>
|
66
|
+
|
67
|
+
<div class="field">
|
68
|
+
<%= f.label :user_number -%><br />
|
69
|
+
<%- if current_user.has_role?('Librarian') -%>
|
70
|
+
<%= f.text_field :user_number, class: 'resource_user_number' -%>
|
71
|
+
<%- else -%>
|
72
|
+
<%= profile.user_number -%>
|
73
|
+
<%- end -%>
|
74
|
+
</div>
|
75
|
+
|
76
|
+
<div class="field">
|
77
|
+
<%= f.label t('activerecord.models.library') -%><br />
|
78
|
+
<%- if current_user.has_role?('Librarian') -%>
|
79
|
+
<%= f.select(:library_id, @libraries.collect{|l| [l.display_name.localize, l.id]}) -%>
|
80
|
+
<% else %>
|
81
|
+
<%= current_user.profile.library.display_name.localize if current_user.profile.library %>
|
82
|
+
<% end %>
|
83
|
+
</div>
|
84
|
+
|
85
|
+
<div class="field">
|
86
|
+
<%= f.label t('role.required_role') -%><br />
|
87
|
+
<%- if current_user.has_role?('Librarian') -%>
|
88
|
+
<%= f.select(:required_role_id, @roles.collect{|r| [r.display_name.localize, r.id]}) -%>
|
89
|
+
<%- else -%>
|
90
|
+
<%= current_user.role.display_name.localize -%>
|
91
|
+
<%- end -%>
|
92
|
+
</div>
|
93
|
+
|
94
|
+
<div class="field">
|
95
|
+
<%= f.label :locale -%><br />
|
96
|
+
<%= f.select(:locale, @available_languages.collect{|language| [language.display_name.localize, language.iso_639_1]}) -%>
|
97
|
+
</div>
|
98
|
+
</div>
|
99
|
+
<% end %>
|
@@ -0,0 +1,24 @@
|
|
1
|
+
<%= form_for(@user) do |f| %>
|
2
|
+
<% if @user.errors.any? %>
|
3
|
+
<div id="errorExplanation">
|
4
|
+
<h2><%= pluralize(@user.errors.count, "error") %> prohibited this user from being saved:</h2>
|
5
|
+
<ul>
|
6
|
+
<% @user.errors.full_messages.each do |msg| %>
|
7
|
+
<li><%= msg %></li>
|
8
|
+
<% end %>
|
9
|
+
</ul>
|
10
|
+
</div>
|
11
|
+
<% end %>
|
12
|
+
|
13
|
+
<div class="field">
|
14
|
+
<%= f.label :username %><br />
|
15
|
+
<%= f.text_field :username %>
|
16
|
+
</div>
|
17
|
+
<div class="field">
|
18
|
+
<%= f.label :email %><br />
|
19
|
+
<%= f.email_field :email %>
|
20
|
+
</div>
|
21
|
+
<div class="actions">
|
22
|
+
<%= f.submit %>
|
23
|
+
</div>
|
24
|
+
<% end %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= render 'page/index' %>
|
@@ -0,0 +1,32 @@
|
|
1
|
+
<div id="content_detail" class="ui-corner-all ui-widget-content">
|
2
|
+
<h1 class="title"><%= t('page.edit_user_profile', login_name: @profile.user.username) -%></h1>
|
3
|
+
<div id="content_list">
|
4
|
+
<%= render 'page/required_field' %>
|
5
|
+
<%= simple_form_for(@profile, url: my_account_path) do |f| -%>
|
6
|
+
<%= f.error_messages -%>
|
7
|
+
|
8
|
+
<%= render partial: 'edit_credential', locals: {f: f, profile: @profile} -%>
|
9
|
+
|
10
|
+
<div class="actions" style="clear: both">
|
11
|
+
<%= f.submit %>
|
12
|
+
</div>
|
13
|
+
<div class="field">
|
14
|
+
<%= f.label :keyword_list -%><br />
|
15
|
+
<%= f.text_area :keyword_list, class: 'resource_textarea' -%>
|
16
|
+
</div>
|
17
|
+
|
18
|
+
<%= render partial: 'profiles/edit_profile', locals: {f: f, profile: @profile} -%>
|
19
|
+
<%- end -%>
|
20
|
+
|
21
|
+
</div>
|
22
|
+
</div>
|
23
|
+
|
24
|
+
<div id="submenu" class="ui-corner-all ui-widget-content">
|
25
|
+
<ul>
|
26
|
+
<li><%= link_to t('page.show'), my_account_path -%></li>
|
27
|
+
<% if current_user.has_role?('Librarian') %>
|
28
|
+
<li><%= link_to t('page.listing', model: t('activerecord.models.user')), profiles_path -%></li>
|
29
|
+
<% end %>
|
30
|
+
<li><%= link_to t('activerecord.models.registration'), edit_user_registration_path -%></li>
|
31
|
+
</ul>
|
32
|
+
</div>
|
@@ -0,0 +1,49 @@
|
|
1
|
+
<div id="content_detail" class="ui-corner-all ui-widget-content">
|
2
|
+
<h1 class="title"><%= t('page.showing', model: t('activerecord.models.user')) -%></h1>
|
3
|
+
<div id="content_list">
|
4
|
+
<p id="notice"><%= notice %></p>
|
5
|
+
|
6
|
+
<h2 class="resource_title">
|
7
|
+
[U]
|
8
|
+
<%= current_user.username -%>
|
9
|
+
</h2>
|
10
|
+
|
11
|
+
<p><%= t('activerecord.attributes.profile.user_number') %>: <%= @profile.user_number %></p>
|
12
|
+
<% if defined?(EnjuOrcid) %>
|
13
|
+
<p><%= 'ORCID iD' %>: <%= link_to orcid_url(@profile), orcid_url(@profile) %></p>
|
14
|
+
<% end %>
|
15
|
+
|
16
|
+
<% if defined?(EnjuCirculation) %>
|
17
|
+
<%= render 'profiles/checkout_list', profile: @profile %>
|
18
|
+
<% end %>
|
19
|
+
</div>
|
20
|
+
</div>
|
21
|
+
|
22
|
+
<div id="submenu" class="ui-corner-all ui-widget-content">
|
23
|
+
<% if defined?(EnjuCirculation) %>
|
24
|
+
<%= render 'profiles/submenu_checkout', profile: @profile %>
|
25
|
+
<% end %>
|
26
|
+
<ul>
|
27
|
+
<li><%= link_to t('page.edit'), edit_my_account_path -%></li>
|
28
|
+
<li><%= link_to t('activerecord.models.registration'), edit_user_registration_path -%></li>
|
29
|
+
<%- if policy(@profile).destroy? -%>
|
30
|
+
<li><%= link_to t('page.destroy'), @profile, data: {confirm: t('page.are_you_sure')}, method: :delete -%></li>
|
31
|
+
<%- end -%>
|
32
|
+
<% if defined?(EnjuSearchLog) %>
|
33
|
+
<li><%= link_to t('activerecord.models.search_history'), search_histories_path %></li>
|
34
|
+
<% end %>
|
35
|
+
<% if defined?(EnjuCirculation) %>
|
36
|
+
<li><%= link_to t('page.listing', model: t('activerecord.models.checkout')), checkouts_path(user_id: @profile.user.username) %></li>
|
37
|
+
<li><%= link_to t('page.listing', model: t('activerecord.models.reserve')), reserves_path(user_id: @profile.user.username) %></li>
|
38
|
+
<% end %>
|
39
|
+
<% if defined?(EnjuQuestion) %>
|
40
|
+
<li><%= link_to t('page.listing', model: t('activerecord.models.question')), questions_path(user_id: @profile.user.username) %></li>
|
41
|
+
<% end %>
|
42
|
+
<% if defined?(EnjuBookmark) %>
|
43
|
+
<li><%= link_to t('page.listing', model: t('activerecord.models.bookmark')), bookmarks_path(user_id: @profile.user.username) %></li>
|
44
|
+
<% end %>
|
45
|
+
<% if defined?(EnjuPurchaseRequest) %>
|
46
|
+
<li><%= link_to t('page.listing', model: t('activerecord.models.purchase_request')), purchase_requests_path(user_id: @profile.user.username) %></li>
|
47
|
+
<% end %>
|
48
|
+
</ul>
|
49
|
+
</div>
|
@@ -34,9 +34,9 @@
|
|
34
34
|
<%= user_form.label t('activerecord.models.role') -%><br />
|
35
35
|
<%= user_form.fields_for :user_has_role do |u| %>
|
36
36
|
<%- if current_user.has_role?('Administrator') and current_user != profile.user -%>
|
37
|
-
<%= u.select :role_id, @roles.select{|r| r.name != 'Guest' }.collect{|r| [r.display_name, r.id]} %>
|
37
|
+
<%= u.select :role_id, @roles.select{|r| r.name != 'Guest' }.collect{|r| [r.display_name.localize, r.id]} %>
|
38
38
|
<% else %>
|
39
|
-
<%= u.select :role_id, @roles.select{|r| r.name != 'Guest' }.collect{|r| [r.display_name, r.id]}, {}, {disabled: 'disabled'} %>
|
39
|
+
<%= u.select :role_id, @roles.select{|r| r.name != 'Guest' }.collect{|r| [r.display_name.localize, r.id]}, {}, {disabled: 'disabled'} %>
|
40
40
|
<% end %>
|
41
41
|
<% end %>
|
42
42
|
</div>
|
@@ -56,7 +56,7 @@
|
|
56
56
|
<%- if current_user.has_role?('Librarian') -%>
|
57
57
|
<div class="field">
|
58
58
|
<%= f.label t('activerecord.models.user_group') -%><br />
|
59
|
-
<%= f.select(:user_group_id, @user_groups.collect{|u| [u.display_name, u.id]}) -%>
|
59
|
+
<%= f.select(:user_group_id, @user_groups.collect{|u| [u.display_name.localize, u.id]}) -%>
|
60
60
|
</div>
|
61
61
|
<%- end -%>
|
62
62
|
|
@@ -72,17 +72,17 @@
|
|
72
72
|
<%- if current_user.has_role?('Librarian') -%>
|
73
73
|
<div class="field">
|
74
74
|
<%= f.label t('activerecord.models.library') -%><br />
|
75
|
-
<%= f.select(:library_id, @libraries.collect{|l| [l.display_name, l.id]}) -%>
|
75
|
+
<%= f.select(:library_id, @libraries.collect{|l| [l.display_name.localize, l.id]}) -%>
|
76
76
|
</div>
|
77
77
|
|
78
78
|
<div class="field">
|
79
79
|
<%= f.label t('role.required_role') -%><br />
|
80
|
-
<%= f.select(:required_role_id, @roles.collect{|r| [r.display_name, r.id]}) -%>
|
80
|
+
<%= f.select(:required_role_id, @roles.collect{|r| [r.display_name.localize, r.id]}) -%>
|
81
81
|
</div>
|
82
82
|
<%- end -%>
|
83
83
|
<div class="field">
|
84
84
|
<%= f.label :locale -%><br />
|
85
|
-
<%= f.select(:locale, @available_languages.collect{|language| [language.display_name, language.iso_639_1]}) -%>
|
85
|
+
<%= f.select(:locale, @available_languages.collect{|language| [language.display_name.localize, language.iso_639_1]}) -%>
|
86
86
|
</div>
|
87
87
|
</div>
|
88
88
|
<% end %>
|
@@ -0,0 +1,42 @@
|
|
1
|
+
<% if defined?(EnjuCirculation) %>
|
2
|
+
<div class="field">
|
3
|
+
<%= f.label t('user.checkout_history_icalendar_url') -%><br />
|
4
|
+
<div id="feed_token">
|
5
|
+
<%- if profile.checkout_icalendar_token? -%>
|
6
|
+
<%= link_to checkouts_url(icalendar_token: profile.checkout_icalendar_token, format: :ics), checkouts_url(icalendar_token: profile.checkout_icalendar_token, format: :ics) -%>
|
7
|
+
<%= f.hidden_field :checkout_icalendar_token -%>
|
8
|
+
<%- end -%>
|
9
|
+
<br />
|
10
|
+
<input onclick="$.ajax({data:'authenticity_token=' + encodeURIComponent('<%= form_authenticity_token %>'), success:function(request){$('#feed_token').html(request);}, type:'get', url:'<%= edit_profile_path(profile, mode: 'feed_token') %>'});" type="button" value="<%= t('page.reset') %>" />
|
11
|
+
<input onclick="$.ajax({data:'authenticity_token=' + encodeURIComponent('<%= form_authenticity_token %>'), success:function(request){$('#feed_token').html(request);}, type:'get', url:'<%= edit_profile_path(profile, disable: true, mode: 'feed_token') %>'});" type="button" value="<%= t('page.delete') %>" />
|
12
|
+
</div>
|
13
|
+
<br />
|
14
|
+
</div>
|
15
|
+
<% end %>
|
16
|
+
|
17
|
+
<% if defined?(EnjuSearchLog) %>
|
18
|
+
<div class="field">
|
19
|
+
<%= f.label :save_search_history %>
|
20
|
+
<%= f.check_box :save_search_history %>
|
21
|
+
</div>
|
22
|
+
<% end %>
|
23
|
+
|
24
|
+
<% if defined?(EnjuCirculation) %>
|
25
|
+
<div class="field">
|
26
|
+
<%= f.label :save_checkout_history %>
|
27
|
+
<%= f.check_box :save_checkout_history %>
|
28
|
+
</div>
|
29
|
+
<% end %>
|
30
|
+
|
31
|
+
<% if current_user.has_role?('Librarian') %>
|
32
|
+
<div class="field">
|
33
|
+
<%= f.label :note -%><br />
|
34
|
+
<%= f.text_area :note, class: 'resource_textarea' -%>
|
35
|
+
</div>
|
36
|
+
<% end %>
|
37
|
+
|
38
|
+
<div class="actions">
|
39
|
+
<%= f.submit %>
|
40
|
+
</div>
|
41
|
+
|
42
|
+
|
@@ -0,0 +1,15 @@
|
|
1
|
+
<%= form_for(@user) do |f| %>
|
2
|
+
<%= f.error_notification -%>
|
3
|
+
|
4
|
+
<div class="field">
|
5
|
+
<%= f.label :username %><br />
|
6
|
+
<%= f.text_field :username %>
|
7
|
+
</div>
|
8
|
+
<div class="field">
|
9
|
+
<%= f.label :email %><br />
|
10
|
+
<%= f.email_field :email %>
|
11
|
+
</div>
|
12
|
+
<div class="actions">
|
13
|
+
<%= f.submit %>
|
14
|
+
</div>
|
15
|
+
<% end %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= render 'page/index' %>
|
@@ -0,0 +1,33 @@
|
|
1
|
+
<div id="content_detail" class="ui-corner-all ui-widget-content">
|
2
|
+
<h1 class="title"><%= t('page.edit_user_profile', login_name: @profile.user.username) -%></h1>
|
3
|
+
<div id="content_list">
|
4
|
+
<%= render 'page/required_field' %>
|
5
|
+
<%= simple_form_for(@profile, validate: true) do |f| -%>
|
6
|
+
<%= f.error_messages -%>
|
7
|
+
|
8
|
+
<%= render partial: 'profiles/edit_credential', locals: {f: f, profile: @profile} -%>
|
9
|
+
|
10
|
+
<div class="actions" style="clear: both">
|
11
|
+
<%= f.submit %>
|
12
|
+
</div>
|
13
|
+
|
14
|
+
<div class="field">
|
15
|
+
<%= f.label :keyword_list -%><br />
|
16
|
+
<%= f.text_area :keyword_list, class: 'resource_textarea' -%>
|
17
|
+
</div>
|
18
|
+
|
19
|
+
<%= render partial: 'profiles/edit_profile', locals: {f: f, profile: @profile} -%>
|
20
|
+
<%- end -%>
|
21
|
+
|
22
|
+
</div>
|
23
|
+
</div>
|
24
|
+
|
25
|
+
<div id="submenu" class="ui-corner-all ui-widget-content">
|
26
|
+
<ul>
|
27
|
+
<li><%= link_to t('page.show'), @profile -%></li>
|
28
|
+
<li><%= link_to t('page.listing', model: t('activerecord.models.profile')), profiles_path -%></li>
|
29
|
+
<%- if policy(@profile).destroy? -%>
|
30
|
+
<li><%= link_to t('page.destroy'), @profile, data: {confirm: t('page.are_you_sure')}, method: :delete -%></li>
|
31
|
+
<%- end -%>
|
32
|
+
</ul>
|
33
|
+
</div>
|