active_scaffold 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.autotest +27 -0
- data/CHANGELOG +152 -0
- data/Gemfile +4 -0
- data/MIT-LICENSE +20 -0
- data/README +51 -0
- data/Rakefile +24 -0
- data/active_scaffold.gemspec +24 -0
- data/environment.rb +22 -0
- data/frontends/default/images/add.gif +0 -0
- data/frontends/default/images/arrow_down.gif +0 -0
- data/frontends/default/images/arrow_up.gif +0 -0
- data/frontends/default/images/close.gif +0 -0
- data/frontends/default/images/cross.png +0 -0
- data/frontends/default/images/indicator-small.gif +0 -0
- data/frontends/default/images/indicator.gif +0 -0
- data/frontends/default/images/magnifier.png +0 -0
- data/frontends/default/javascripts/jquery/active_scaffold.js +957 -0
- data/frontends/default/javascripts/jquery/jquery.editinplace.js +726 -0
- data/frontends/default/javascripts/prototype/active_scaffold.js +954 -0
- data/frontends/default/javascripts/prototype/dhtml_history.js +867 -0
- data/frontends/default/javascripts/prototype/form_enhancements.js +117 -0
- data/frontends/default/javascripts/prototype/rico_corner.js +370 -0
- data/frontends/default/stylesheets/stylesheet-ie.css +35 -0
- data/frontends/default/stylesheets/stylesheet.css +858 -0
- data/frontends/default/views/_add_existing_form.html.erb +30 -0
- data/frontends/default/views/_base_form.html.erb +41 -0
- data/frontends/default/views/_create_form.html.erb +6 -0
- data/frontends/default/views/_create_form_on_list.html.erb +5 -0
- data/frontends/default/views/_field_search.html.erb +32 -0
- data/frontends/default/views/_form.html.erb +24 -0
- data/frontends/default/views/_form_association.html.erb +14 -0
- data/frontends/default/views/_form_association_footer.html.erb +40 -0
- data/frontends/default/views/_form_attribute.html.erb +15 -0
- data/frontends/default/views/_form_hidden_attribute.html.erb +2 -0
- data/frontends/default/views/_form_messages.html.erb +5 -0
- data/frontends/default/views/_horizontal_subform.html.erb +19 -0
- data/frontends/default/views/_horizontal_subform_header.html.erb +10 -0
- data/frontends/default/views/_horizontal_subform_record.html.erb +37 -0
- data/frontends/default/views/_human_conditions.html.erb +1 -0
- data/frontends/default/views/_list.html.erb +18 -0
- data/frontends/default/views/_list_actions.html.erb +16 -0
- data/frontends/default/views/_list_calculations.html.erb +16 -0
- data/frontends/default/views/_list_column_headings.html.erb +12 -0
- data/frontends/default/views/_list_header.html.erb +12 -0
- data/frontends/default/views/_list_inline_adapter.html.erb +10 -0
- data/frontends/default/views/_list_messages.html.erb +32 -0
- data/frontends/default/views/_list_pagination.html.erb +11 -0
- data/frontends/default/views/_list_pagination_links.html.erb +9 -0
- data/frontends/default/views/_list_record.html.erb +14 -0
- data/frontends/default/views/_list_record_columns.html.erb +8 -0
- data/frontends/default/views/_list_with_header.html.erb +32 -0
- data/frontends/default/views/_messages.html.erb +10 -0
- data/frontends/default/views/_render_field.js.rjs +13 -0
- data/frontends/default/views/_row.html.erb +12 -0
- data/frontends/default/views/_search.html.erb +34 -0
- data/frontends/default/views/_search_attribute.html.erb +10 -0
- data/frontends/default/views/_show.html.erb +8 -0
- data/frontends/default/views/_show_columns.html.erb +12 -0
- data/frontends/default/views/_update_actions.html.erb +9 -0
- data/frontends/default/views/_update_form.html.erb +5 -0
- data/frontends/default/views/_vertical_subform.html.erb +12 -0
- data/frontends/default/views/_vertical_subform_record.html.erb +38 -0
- data/frontends/default/views/add_existing.js.rjs +17 -0
- data/frontends/default/views/add_existing_form.html.erb +5 -0
- data/frontends/default/views/create.html.erb +5 -0
- data/frontends/default/views/delete.html.erb +13 -0
- data/frontends/default/views/destroy.js.rjs +5 -0
- data/frontends/default/views/edit_associated.js.rjs +11 -0
- data/frontends/default/views/field_search.html.erb +5 -0
- data/frontends/default/views/form_messages.js.rjs +1 -0
- data/frontends/default/views/list.html.erb +1 -0
- data/frontends/default/views/list.js.rjs +1 -0
- data/frontends/default/views/on_action_update.js.rjs +8 -0
- data/frontends/default/views/on_create.js.rjs +24 -0
- data/frontends/default/views/on_update.js.rjs +15 -0
- data/frontends/default/views/search.html.erb +5 -0
- data/frontends/default/views/show.html.erb +5 -0
- data/frontends/default/views/update.html.erb +8 -0
- data/frontends/default/views/update_column.js.rjs +13 -0
- data/frontends/default/views/update_row.js.rjs +1 -0
- data/init.rb +1 -0
- data/install_assets.rb +44 -0
- data/lib/active_record_permissions.rb +134 -0
- data/lib/active_scaffold.rb +279 -0
- data/lib/active_scaffold/actions/common_search.rb +22 -0
- data/lib/active_scaffold/actions/core.rb +150 -0
- data/lib/active_scaffold/actions/create.rb +152 -0
- data/lib/active_scaffold/actions/delete.rb +72 -0
- data/lib/active_scaffold/actions/field_search.rb +82 -0
- data/lib/active_scaffold/actions/list.rb +128 -0
- data/lib/active_scaffold/actions/mark.rb +50 -0
- data/lib/active_scaffold/actions/nested.rb +241 -0
- data/lib/active_scaffold/actions/search.rb +47 -0
- data/lib/active_scaffold/actions/show.rb +54 -0
- data/lib/active_scaffold/actions/subform.rb +17 -0
- data/lib/active_scaffold/actions/update.rb +134 -0
- data/lib/active_scaffold/attribute_params.rb +207 -0
- data/lib/active_scaffold/bridges/ancestry/bridge.rb +5 -0
- data/lib/active_scaffold/bridges/ancestry/lib/ancestry_bridge.rb +38 -0
- data/lib/active_scaffold/bridges/bridge.rb +52 -0
- data/lib/active_scaffold/bridges/calendar_date_select/bridge.rb +16 -0
- data/lib/active_scaffold/bridges/calendar_date_select/lib/as_cds_bridge.rb +79 -0
- data/lib/active_scaffold/bridges/carrierwave/bridge.rb +7 -0
- data/lib/active_scaffold/bridges/carrierwave/lib/carrierwave_bridge.rb +38 -0
- data/lib/active_scaffold/bridges/carrierwave/lib/carrierwave_bridge_helpers.rb +26 -0
- data/lib/active_scaffold/bridges/carrierwave/lib/form_ui.rb +35 -0
- data/lib/active_scaffold/bridges/carrierwave/lib/list_ui.rb +17 -0
- data/lib/active_scaffold/bridges/date_picker/bridge.rb +22 -0
- data/lib/active_scaffold/bridges/date_picker/lib/datepicker_bridge.rb +225 -0
- data/lib/active_scaffold/bridges/date_picker/public/javascripts/date_picker_bridge.js +22 -0
- data/lib/active_scaffold/bridges/file_column/bridge.rb +11 -0
- data/lib/active_scaffold/bridges/file_column/lib/as_file_column_bridge.rb +46 -0
- data/lib/active_scaffold/bridges/file_column/lib/file_column_helpers.rb +59 -0
- data/lib/active_scaffold/bridges/file_column/lib/form_ui.rb +37 -0
- data/lib/active_scaffold/bridges/file_column/lib/list_ui.rb +26 -0
- data/lib/active_scaffold/bridges/file_column/test/functional/file_column_keep_test.rb +43 -0
- data/lib/active_scaffold/bridges/file_column/test/mock_model.rb +9 -0
- data/lib/active_scaffold/bridges/file_column/test/test_helper.rb +15 -0
- data/lib/active_scaffold/bridges/paperclip/bridge.rb +12 -0
- data/lib/active_scaffold/bridges/paperclip/lib/form_ui.rb +27 -0
- data/lib/active_scaffold/bridges/paperclip/lib/list_ui.rb +16 -0
- data/lib/active_scaffold/bridges/paperclip/lib/paperclip_bridge.rb +38 -0
- data/lib/active_scaffold/bridges/paperclip/lib/paperclip_bridge_helpers.rb +26 -0
- data/lib/active_scaffold/bridges/semantic_attributes/bridge.rb +5 -0
- data/lib/active_scaffold/bridges/semantic_attributes/lib/semantic_attributes_bridge.rb +20 -0
- data/lib/active_scaffold/bridges/shared/date_bridge.rb +187 -0
- data/lib/active_scaffold/bridges/tiny_mce/bridge.rb +5 -0
- data/lib/active_scaffold/bridges/tiny_mce/lib/tiny_mce_bridge.rb +45 -0
- data/lib/active_scaffold/bridges/validation_reflection/bridge.rb +8 -0
- data/lib/active_scaffold/bridges/validation_reflection/lib/validation_reflection_bridge.rb +21 -0
- data/lib/active_scaffold/config/base.rb +54 -0
- data/lib/active_scaffold/config/core.rb +229 -0
- data/lib/active_scaffold/config/create.rb +43 -0
- data/lib/active_scaffold/config/delete.rb +25 -0
- data/lib/active_scaffold/config/field_search.rb +74 -0
- data/lib/active_scaffold/config/form.rb +46 -0
- data/lib/active_scaffold/config/list.rb +174 -0
- data/lib/active_scaffold/config/mark.rb +22 -0
- data/lib/active_scaffold/config/nested.rb +43 -0
- data/lib/active_scaffold/config/search.rb +68 -0
- data/lib/active_scaffold/config/show.rb +34 -0
- data/lib/active_scaffold/config/subform.rb +35 -0
- data/lib/active_scaffold/config/update.rb +38 -0
- data/lib/active_scaffold/configurable.rb +29 -0
- data/lib/active_scaffold/constraints.rb +179 -0
- data/lib/active_scaffold/data_structures/action_columns.rb +133 -0
- data/lib/active_scaffold/data_structures/action_link.rb +162 -0
- data/lib/active_scaffold/data_structures/action_links.rb +59 -0
- data/lib/active_scaffold/data_structures/actions.rb +45 -0
- data/lib/active_scaffold/data_structures/column.rb +348 -0
- data/lib/active_scaffold/data_structures/columns.rb +75 -0
- data/lib/active_scaffold/data_structures/error_message.rb +24 -0
- data/lib/active_scaffold/data_structures/nested_info.rb +108 -0
- data/lib/active_scaffold/data_structures/set.rb +62 -0
- data/lib/active_scaffold/data_structures/sorting.rb +168 -0
- data/lib/active_scaffold/finder.rb +333 -0
- data/lib/active_scaffold/helpers/association_helpers.rb +40 -0
- data/lib/active_scaffold/helpers/controller_helpers.rb +40 -0
- data/lib/active_scaffold/helpers/country_helpers.rb +352 -0
- data/lib/active_scaffold/helpers/form_column_helpers.rb +343 -0
- data/lib/active_scaffold/helpers/human_condition_helpers.rb +59 -0
- data/lib/active_scaffold/helpers/id_helpers.rb +131 -0
- data/lib/active_scaffold/helpers/list_column_helpers.rb +363 -0
- data/lib/active_scaffold/helpers/pagination_helpers.rb +55 -0
- data/lib/active_scaffold/helpers/search_column_helpers.rb +238 -0
- data/lib/active_scaffold/helpers/show_column_helpers.rb +46 -0
- data/lib/active_scaffold/helpers/view_helpers.rb +315 -0
- data/lib/active_scaffold/locale/de.rb +113 -0
- data/lib/active_scaffold/locale/en.rb +118 -0
- data/lib/active_scaffold/locale/es.yml +112 -0
- data/lib/active_scaffold/locale/fr.rb +113 -0
- data/lib/active_scaffold/locale/hu.yml +63 -0
- data/lib/active_scaffold/locale/ja.yml +64 -0
- data/lib/active_scaffold/locale/ru.yml +62 -0
- data/lib/active_scaffold/marked_model.rb +38 -0
- data/lib/dhtml_confirm.rb +54 -0
- data/lib/extensions/action_controller_rendering.rb +20 -0
- data/lib/extensions/action_view_rendering.rb +113 -0
- data/lib/extensions/action_view_resolver.rb +7 -0
- data/lib/extensions/active_record_offset.rb +12 -0
- data/lib/extensions/array.rb +7 -0
- data/lib/extensions/localize.rb +10 -0
- data/lib/extensions/name_option_for_datetime.rb +12 -0
- data/lib/extensions/nil_id_in_url_params.rb +7 -0
- data/lib/extensions/paginator_extensions.rb +26 -0
- data/lib/extensions/reverse_associations.rb +62 -0
- data/lib/extensions/routing_mapper.rb +34 -0
- data/lib/extensions/to_label.rb +8 -0
- data/lib/extensions/unsaved_associated.rb +61 -0
- data/lib/extensions/unsaved_record.rb +20 -0
- data/lib/extensions/usa_state.rb +46 -0
- data/lib/generators/active_scaffold/USAGE +29 -0
- data/lib/generators/active_scaffold/active_scaffold_generator.rb +20 -0
- data/lib/generators/active_scaffold_controller/USAGE +19 -0
- data/lib/generators/active_scaffold_controller/active_scaffold_controller_generator.rb +28 -0
- data/lib/generators/active_scaffold_controller/templates/controller.rb +4 -0
- data/lib/generators/active_scaffold_setup/USAGE +10 -0
- data/lib/generators/active_scaffold_setup/active_scaffold_setup_generator.rb +53 -0
- data/lib/paginator.rb +136 -0
- data/lib/responds_to_parent.rb +70 -0
- data/public/blank.html +33 -0
- data/shoulda_macros/macros.rb +136 -0
- data/test/bridges/bridge_test.rb +47 -0
- data/test/config/base_test.rb +15 -0
- data/test/config/create_test.rb +55 -0
- data/test/config/list_test.rb +74 -0
- data/test/config/show_test.rb +43 -0
- data/test/config/update_test.rb +17 -0
- data/test/const_mocker.rb +36 -0
- data/test/data_structures/action_columns_test.rb +113 -0
- data/test/data_structures/action_link_test.rb +78 -0
- data/test/data_structures/action_links_test.rb +78 -0
- data/test/data_structures/actions_test.rb +25 -0
- data/test/data_structures/association_column_test.rb +42 -0
- data/test/data_structures/column_test.rb +185 -0
- data/test/data_structures/columns_test.rb +69 -0
- data/test/data_structures/error_message_test.rb +28 -0
- data/test/data_structures/set_test.rb +86 -0
- data/test/data_structures/sorting_test.rb +126 -0
- data/test/data_structures/standard_column_test.rb +24 -0
- data/test/data_structures/virtual_column_test.rb +23 -0
- data/test/extensions/active_record_test.rb +45 -0
- data/test/extensions/array_test.rb +12 -0
- data/test/helpers/form_column_helpers_test.rb +31 -0
- data/test/helpers/list_column_helpers_test.rb +31 -0
- data/test/helpers/pagination_helpers_test.rb +55 -0
- data/test/misc/active_record_permissions_test.rb +154 -0
- data/test/misc/attribute_params_test.rb +110 -0
- data/test/misc/configurable_test.rb +96 -0
- data/test/misc/constraints_test.rb +193 -0
- data/test/misc/finder_test.rb +93 -0
- data/test/misc/lang_test.rb +12 -0
- data/test/mock_app/.gitignore +2 -0
- data/test/mock_app/app/controllers/application_controller.rb +10 -0
- data/test/mock_app/app/helpers/application_helper.rb +3 -0
- data/test/mock_app/config/boot.rb +110 -0
- data/test/mock_app/config/database.yml +16 -0
- data/test/mock_app/config/environment.rb +43 -0
- data/test/mock_app/config/environments/development.rb +17 -0
- data/test/mock_app/config/environments/production.rb +28 -0
- data/test/mock_app/config/environments/test.rb +28 -0
- data/test/mock_app/config/initializers/backtrace_silencers.rb +7 -0
- data/test/mock_app/config/initializers/inflections.rb +10 -0
- data/test/mock_app/config/initializers/mime_types.rb +5 -0
- data/test/mock_app/config/initializers/new_rails_defaults.rb +19 -0
- data/test/mock_app/config/initializers/session_store.rb +15 -0
- data/test/mock_app/config/locales/en.yml +5 -0
- data/test/mock_app/config/routes.rb +43 -0
- data/test/mock_app/db/test.sqlite3 +1 -0
- data/test/mock_app/public/blank.html +33 -0
- data/test/mock_app/public/images/active_scaffold/DO_NOT_EDIT +2 -0
- data/test/mock_app/public/images/active_scaffold/default/add.gif +0 -0
- data/test/mock_app/public/images/active_scaffold/default/arrow_down.gif +0 -0
- data/test/mock_app/public/images/active_scaffold/default/arrow_up.gif +0 -0
- data/test/mock_app/public/images/active_scaffold/default/close.gif +0 -0
- data/test/mock_app/public/images/active_scaffold/default/cross.png +0 -0
- data/test/mock_app/public/images/active_scaffold/default/indicator-small.gif +0 -0
- data/test/mock_app/public/images/active_scaffold/default/indicator.gif +0 -0
- data/test/mock_app/public/images/active_scaffold/default/magnifier.png +0 -0
- data/test/mock_app/public/javascripts/active_scaffold/DO_NOT_EDIT +2 -0
- data/test/mock_app/public/javascripts/active_scaffold/default/active_scaffold.js +532 -0
- data/test/mock_app/public/javascripts/active_scaffold/default/dhtml_history.js +867 -0
- data/test/mock_app/public/javascripts/active_scaffold/default/form_enhancements.js +117 -0
- data/test/mock_app/public/javascripts/active_scaffold/default/rico_corner.js +370 -0
- data/test/mock_app/public/stylesheets/active_scaffold/DO_NOT_EDIT +2 -0
- data/test/mock_app/public/stylesheets/active_scaffold/default/stylesheet-ie.css +35 -0
- data/test/mock_app/public/stylesheets/active_scaffold/default/stylesheet.css +839 -0
- data/test/model_stub.rb +55 -0
- data/test/run_all.rb +8 -0
- data/test/test_helper.rb +39 -0
- data/uninstall.rb +13 -0
- metadata +478 -0
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
module ActiveScaffold
|
|
2
|
+
module Helpers
|
|
3
|
+
module PaginationHelpers
|
|
4
|
+
def pagination_ajax_link(page_number, url_options, options)
|
|
5
|
+
link_to page_number, url_options.merge(:page => page_number), options.merge(:class => "as_paginate")
|
|
6
|
+
end
|
|
7
|
+
|
|
8
|
+
def pagination_ajax_links(current_page, url_options, options, window_size)
|
|
9
|
+
start_number = current_page.number - window_size
|
|
10
|
+
end_number = current_page.number + window_size
|
|
11
|
+
start_number = 1 if start_number <= 0
|
|
12
|
+
if current_page.pager.infinite?
|
|
13
|
+
offsets = [20, 100]
|
|
14
|
+
else
|
|
15
|
+
end_number = current_page.pager.last.number if end_number > current_page.pager.last.number
|
|
16
|
+
end
|
|
17
|
+
|
|
18
|
+
html = []
|
|
19
|
+
unless start_number == 1
|
|
20
|
+
last_page = 1
|
|
21
|
+
html << pagination_ajax_link(last_page, url_options, options)
|
|
22
|
+
if current_page.pager.infinite?
|
|
23
|
+
offsets.reverse.each do |offset|
|
|
24
|
+
page = current_page.number - offset
|
|
25
|
+
if page < start_number && page > 1
|
|
26
|
+
html << '..' if page > last_page + 1
|
|
27
|
+
html << pagination_ajax_link(page, params)
|
|
28
|
+
last_page = page
|
|
29
|
+
end
|
|
30
|
+
end
|
|
31
|
+
end
|
|
32
|
+
html << ".." if start_number > last_page + 1
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
start_number.upto(end_number) do |num|
|
|
36
|
+
if current_page.number == num
|
|
37
|
+
html << content_tag(:span, num.to_s, {:class => "as_paginate current"})
|
|
38
|
+
else
|
|
39
|
+
html << pagination_ajax_link(num, url_options, options)
|
|
40
|
+
end
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
if current_page.pager.infinite?
|
|
44
|
+
offsets.each do |offset|
|
|
45
|
+
html << '..' << pagination_ajax_link(current_page.number + offset, url_options, options)
|
|
46
|
+
end
|
|
47
|
+
else
|
|
48
|
+
html << ".." unless end_number >= current_page.pager.last.number - 1
|
|
49
|
+
html << pagination_ajax_link(current_page.pager.last.number, url_options, options) unless end_number == current_page.pager.last.number
|
|
50
|
+
end
|
|
51
|
+
html.join(' ').html_safe
|
|
52
|
+
end
|
|
53
|
+
end
|
|
54
|
+
end
|
|
55
|
+
end
|
|
@@ -0,0 +1,238 @@
|
|
|
1
|
+
module ActiveScaffold
|
|
2
|
+
module Helpers
|
|
3
|
+
# Helpers that assist with the rendering of a Form Column
|
|
4
|
+
module SearchColumnHelpers
|
|
5
|
+
# This method decides which input to use for the given column.
|
|
6
|
+
# It does not do any rendering. It only decides which method is responsible for rendering.
|
|
7
|
+
def active_scaffold_search_for(column)
|
|
8
|
+
options = active_scaffold_search_options(column)
|
|
9
|
+
|
|
10
|
+
# first, check if the dev has created an override for this specific field for search
|
|
11
|
+
if override_search_field?(column)
|
|
12
|
+
send(override_search_field(column), @record, options)
|
|
13
|
+
|
|
14
|
+
# second, check if the dev has specified a valid search_ui for this column, using specific ui for searches
|
|
15
|
+
elsif column.search_ui and override_search?(column.search_ui)
|
|
16
|
+
send(override_search(column.search_ui), column, options)
|
|
17
|
+
|
|
18
|
+
# third, check if the dev has specified a valid search_ui for this column, using generic ui for forms
|
|
19
|
+
elsif column.search_ui and override_input?(column.search_ui)
|
|
20
|
+
send(override_input(column.search_ui), column, options)
|
|
21
|
+
|
|
22
|
+
# fourth, check if the dev has created an override for this specific field
|
|
23
|
+
elsif override_form_field?(column)
|
|
24
|
+
send(override_form_field(column), @record, options)
|
|
25
|
+
|
|
26
|
+
# fallback: we get to make the decision
|
|
27
|
+
else
|
|
28
|
+
if column.association or column.virtual?
|
|
29
|
+
active_scaffold_search_text(column, options)
|
|
30
|
+
|
|
31
|
+
else # regular model attribute column
|
|
32
|
+
# if we (or someone else) have created a custom render option for the column type, use that
|
|
33
|
+
if override_search?(column.column.type)
|
|
34
|
+
send(override_search(column.column.type), column, options)
|
|
35
|
+
# if we (or someone else) have created a custom render option for the column type, use that
|
|
36
|
+
elsif override_input?(column.column.type)
|
|
37
|
+
send(override_input(column.column.type), column, options)
|
|
38
|
+
# final ultimate fallback: use rails' generic input method
|
|
39
|
+
else
|
|
40
|
+
# for textual fields we pass different options
|
|
41
|
+
text_types = [:text, :string, :integer, :float, :decimal]
|
|
42
|
+
options = active_scaffold_input_text_options(options) if text_types.include?(column.column.type)
|
|
43
|
+
text_field(:record, column.name, options.merge(column.options))
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
end
|
|
48
|
+
|
|
49
|
+
# the standard active scaffold options used for class, name and scope
|
|
50
|
+
def active_scaffold_search_options(column)
|
|
51
|
+
{ :name => "search[#{column.name}]", :class => "#{column.name}-input", :id => "search_#{column.name}", :value => field_search_params[column.name] }
|
|
52
|
+
end
|
|
53
|
+
|
|
54
|
+
##
|
|
55
|
+
## Search input methods
|
|
56
|
+
##
|
|
57
|
+
|
|
58
|
+
def active_scaffold_search_multi_select(column, options)
|
|
59
|
+
associated = options.delete :value
|
|
60
|
+
associated = [associated].compact unless associated.is_a? Array
|
|
61
|
+
associated.collect!(&:to_i)
|
|
62
|
+
|
|
63
|
+
if column.association
|
|
64
|
+
select_options = options_for_association(column.association, false)
|
|
65
|
+
else
|
|
66
|
+
select_options = Array(column.options[:options])
|
|
67
|
+
end
|
|
68
|
+
return as_(:no_options) if select_options.empty?
|
|
69
|
+
|
|
70
|
+
active_scaffold_checkbox_list(column, select_options, associated, options)
|
|
71
|
+
end
|
|
72
|
+
|
|
73
|
+
def active_scaffold_search_select(column, html_options)
|
|
74
|
+
associated = html_options.delete :value
|
|
75
|
+
if column.association
|
|
76
|
+
associated = associated.is_a?(Array) ? associated.map(&:to_i) : associated.to_i unless associated.nil?
|
|
77
|
+
method = column.association.macro == :belongs_to ? column.association.primary_key_name : column.name
|
|
78
|
+
select_options = options_for_association(column.association, true)
|
|
79
|
+
else
|
|
80
|
+
method = column.name
|
|
81
|
+
select_options = Array(column.options[:options])
|
|
82
|
+
end
|
|
83
|
+
|
|
84
|
+
options = { :selected => associated }.merge! column.options
|
|
85
|
+
html_options.merge! column.options[:html_options] || {}
|
|
86
|
+
if html_options[:multiple]
|
|
87
|
+
html_options[:name] += '[]'
|
|
88
|
+
else
|
|
89
|
+
options[:include_blank] ||= as_(:_select_)
|
|
90
|
+
end
|
|
91
|
+
select(:record, method, select_options, options, html_options)
|
|
92
|
+
end
|
|
93
|
+
|
|
94
|
+
def active_scaffold_search_text(column, options)
|
|
95
|
+
text_field :record, column.name, active_scaffold_input_text_options(options)
|
|
96
|
+
end
|
|
97
|
+
|
|
98
|
+
# we can't use active_scaffold_input_boolean because we need to have a nil value even when column can't be null
|
|
99
|
+
# to decide whether search for this field or not
|
|
100
|
+
def active_scaffold_search_boolean(column, options)
|
|
101
|
+
select_options = []
|
|
102
|
+
select_options << [as_(:_select_), nil]
|
|
103
|
+
select_options << [as_(:true), true]
|
|
104
|
+
select_options << [as_(:false), false]
|
|
105
|
+
|
|
106
|
+
select_tag(options[:name], options_for_select(select_options, column.column.type_cast(field_search_params[column.name])))
|
|
107
|
+
end
|
|
108
|
+
# we can't use checkbox ui because it's not possible to decide whether search for this field or not
|
|
109
|
+
alias_method :active_scaffold_search_checkbox, :active_scaffold_search_boolean
|
|
110
|
+
|
|
111
|
+
def active_scaffold_search_null(column, options)
|
|
112
|
+
select_options = []
|
|
113
|
+
select_options << [as_(:_select_), nil]
|
|
114
|
+
select_options.concat ActiveScaffold::Finder::NullComparators.collect {|comp| [as_(comp), comp]}
|
|
115
|
+
select_tag(options[:name], options_for_select(select_options, field_search_params[column.name]))
|
|
116
|
+
end
|
|
117
|
+
|
|
118
|
+
def field_search_params_range_values(column)
|
|
119
|
+
values = field_search_params[column.name]
|
|
120
|
+
return nil if values.nil?
|
|
121
|
+
return values[:opt], values[:from], values[:to]
|
|
122
|
+
end
|
|
123
|
+
|
|
124
|
+
def active_scaffold_search_range(column, options)
|
|
125
|
+
opt_value, from_value, to_value = field_search_params_range_values(column)
|
|
126
|
+
select_options = ActiveScaffold::Finder::NumericComparators.collect {|comp| [as_(comp.downcase.to_sym), comp]}
|
|
127
|
+
select_options.unshift *ActiveScaffold::Finder::StringComparators.collect {|title, comp| [as_(title), comp]} if column.column && column.column.text?
|
|
128
|
+
from_value = controller.class.condition_value_for_numeric(column, from_value)
|
|
129
|
+
to_value = controller.class.condition_value_for_numeric(column, to_value)
|
|
130
|
+
from_value = format_number_value(from_value, column.options) if from_value.is_a?(Numeric)
|
|
131
|
+
to_value = format_number_value(to_value, column.options) if to_value.is_a?(Numeric)
|
|
132
|
+
html = select_tag("#{options[:name]}[opt]",
|
|
133
|
+
options_for_select(select_options, opt_value),
|
|
134
|
+
:id => "#{options[:id]}_opt",
|
|
135
|
+
:class => "as_search_range_option")
|
|
136
|
+
html << ' ' << text_field_tag("#{options[:name]}[from]", from_value, active_scaffold_input_text_options(:id => options[:id], :size => 10))
|
|
137
|
+
html << ' ' << content_tag(:span, (' - ' + text_field_tag("#{options[:name]}[to]", to_value,
|
|
138
|
+
active_scaffold_input_text_options(:id => "#{options[:id]}_to", :size => 10))).html_safe,
|
|
139
|
+
:id => "#{options[:id]}_between", :class => "as_search_range_between", :style => "display:#{(opt_value == 'BETWEEN') ? '' : 'none'}")
|
|
140
|
+
html
|
|
141
|
+
end
|
|
142
|
+
alias_method :active_scaffold_search_integer, :active_scaffold_search_range
|
|
143
|
+
alias_method :active_scaffold_search_decimal, :active_scaffold_search_range
|
|
144
|
+
alias_method :active_scaffold_search_float, :active_scaffold_search_range
|
|
145
|
+
alias_method :active_scaffold_search_string, :active_scaffold_search_range
|
|
146
|
+
|
|
147
|
+
def active_scaffold_search_record_select(column, options)
|
|
148
|
+
value = field_search_record_select_value(column)
|
|
149
|
+
active_scaffold_record_select(column, options, value, column.options[:multiple])
|
|
150
|
+
end
|
|
151
|
+
|
|
152
|
+
def field_search_record_select_value(column)
|
|
153
|
+
begin
|
|
154
|
+
value = field_search_params[column.name]
|
|
155
|
+
unless value.blank?
|
|
156
|
+
if column.options[:multiple]
|
|
157
|
+
column.association.klass.find value.collect!(&:to_i)
|
|
158
|
+
else
|
|
159
|
+
column.association.klass.find(value.to_i)
|
|
160
|
+
end
|
|
161
|
+
end
|
|
162
|
+
rescue Exception => e
|
|
163
|
+
logger.error Time.now.to_s + "Sorry, we are not that smart yet. Attempted to restore search values to search fields but instead got -- #{e.inspect} -- on the ActiveScaffold column = :#{column.name} in #{controller.class}"
|
|
164
|
+
raise e
|
|
165
|
+
end
|
|
166
|
+
end
|
|
167
|
+
|
|
168
|
+
def field_search_datetime_value(value)
|
|
169
|
+
DateTime.new(value[:year].to_i, value[:month].to_i, value[:day].to_i, value[:hour].to_i, value[:minute].to_i, value[:second].to_i) unless value.nil? || value[:year].blank?
|
|
170
|
+
end
|
|
171
|
+
|
|
172
|
+
def active_scaffold_search_datetime(column, options)
|
|
173
|
+
opt_value, from_value, to_value = field_search_params_range_values(column)
|
|
174
|
+
options = column.options.merge(options)
|
|
175
|
+
helper = "select_#{'date' unless options[:discard_date]}#{'time' unless options[:discard_time]}"
|
|
176
|
+
|
|
177
|
+
send(helper, field_search_datetime_value(from_value), {:include_blank => true, :prefix => "#{options[:name]}[from]"}.merge(options)) <<
|
|
178
|
+
' - '.html_safe << send(helper, field_search_datetime_value(to_value), {:include_blank => true, :prefix => "#{options[:name]}[to]"}.merge(options))
|
|
179
|
+
end
|
|
180
|
+
|
|
181
|
+
def active_scaffold_search_date(column, options)
|
|
182
|
+
active_scaffold_search_datetime(column, options.merge!(:discard_time => true))
|
|
183
|
+
end
|
|
184
|
+
def active_scaffold_search_time(column, options)
|
|
185
|
+
active_scaffold_search_datetime(column, options.merge!(:discard_date => true))
|
|
186
|
+
end
|
|
187
|
+
alias_method :active_scaffold_search_timestamp, :active_scaffold_search_datetime
|
|
188
|
+
|
|
189
|
+
##
|
|
190
|
+
## Search column override signatures
|
|
191
|
+
##
|
|
192
|
+
|
|
193
|
+
def override_search_field?(column)
|
|
194
|
+
respond_to?(override_search_field(column))
|
|
195
|
+
end
|
|
196
|
+
|
|
197
|
+
# the naming convention for overriding form fields with helpers
|
|
198
|
+
def override_search_field(column)
|
|
199
|
+
"#{column.name}_search_column"
|
|
200
|
+
end
|
|
201
|
+
|
|
202
|
+
def override_search?(search_ui)
|
|
203
|
+
respond_to?(override_search(search_ui))
|
|
204
|
+
end
|
|
205
|
+
|
|
206
|
+
# the naming convention for overriding search input types with helpers
|
|
207
|
+
def override_search(form_ui)
|
|
208
|
+
"active_scaffold_search_#{form_ui}"
|
|
209
|
+
end
|
|
210
|
+
|
|
211
|
+
def visibles_and_hiddens(search_config)
|
|
212
|
+
visibles = []
|
|
213
|
+
hiddens = []
|
|
214
|
+
search_config.columns.each do |column|
|
|
215
|
+
next unless column.search_sql
|
|
216
|
+
if search_config.optional_columns.include?(column.name) && !searched_by?(column)
|
|
217
|
+
hiddens << column
|
|
218
|
+
else
|
|
219
|
+
visibles << column
|
|
220
|
+
end
|
|
221
|
+
end
|
|
222
|
+
return visibles, hiddens
|
|
223
|
+
end
|
|
224
|
+
|
|
225
|
+
def searched_by?(column)
|
|
226
|
+
value = field_search_params[column.name]
|
|
227
|
+
case value
|
|
228
|
+
when Hash
|
|
229
|
+
!value['from'].blank?
|
|
230
|
+
when String
|
|
231
|
+
!value.blank?
|
|
232
|
+
else
|
|
233
|
+
false
|
|
234
|
+
end
|
|
235
|
+
end
|
|
236
|
+
end
|
|
237
|
+
end
|
|
238
|
+
end
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
module ActiveScaffold
|
|
2
|
+
module Helpers
|
|
3
|
+
# Helpers that assist with the rendering of a List Column
|
|
4
|
+
module ShowColumnHelpers
|
|
5
|
+
def show_column_value(record, column)
|
|
6
|
+
# check for an override helper
|
|
7
|
+
if show_column_override? column
|
|
8
|
+
# we only pass the record as the argument. we previously also passed the formatted_value,
|
|
9
|
+
# but mike perham pointed out that prohibited the usage of overrides to improve on the
|
|
10
|
+
# performance of our default formatting. see issue #138.
|
|
11
|
+
send(show_column_override(column), record)
|
|
12
|
+
# second, check if the dev has specified a valid list_ui for this column
|
|
13
|
+
elsif column.list_ui and override_show_column_ui?(column.list_ui)
|
|
14
|
+
send(override_show_column_ui(column.list_ui), column, record)
|
|
15
|
+
else
|
|
16
|
+
if column.column and override_show_column_ui?(column.column.type)
|
|
17
|
+
send(override_show_column_ui(column.column.type), column, record)
|
|
18
|
+
else
|
|
19
|
+
get_column_value(record, column)
|
|
20
|
+
end
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
def active_scaffold_show_text(column, record)
|
|
25
|
+
simple_format(clean_column_value(record.send(column.name)))
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
def show_column_override(column)
|
|
29
|
+
"#{column.name.to_s.gsub('?', '')}_show_column" # parse out any question marks (see issue 227)
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
def show_column_override?(column)
|
|
33
|
+
respond_to?(show_column_override(column))
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
def override_show_column_ui?(list_ui)
|
|
37
|
+
respond_to?(override_show_column_ui(list_ui))
|
|
38
|
+
end
|
|
39
|
+
|
|
40
|
+
# the naming convention for overriding show types with helpers
|
|
41
|
+
def override_show_column_ui(list_ui)
|
|
42
|
+
"active_scaffold_show_#{list_ui}"
|
|
43
|
+
end
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
end
|
|
@@ -0,0 +1,315 @@
|
|
|
1
|
+
module ActiveScaffold
|
|
2
|
+
module Helpers
|
|
3
|
+
# All extra helpers that should be included in the View.
|
|
4
|
+
# Also a dumping ground for uncategorized helpers.
|
|
5
|
+
module ViewHelpers
|
|
6
|
+
include ActiveScaffold::Helpers::IdHelpers
|
|
7
|
+
include ActiveScaffold::Helpers::AssociationHelpers
|
|
8
|
+
include ActiveScaffold::Helpers::PaginationHelpers
|
|
9
|
+
include ActiveScaffold::Helpers::ListColumnHelpers
|
|
10
|
+
include ActiveScaffold::Helpers::ShowColumnHelpers
|
|
11
|
+
include ActiveScaffold::Helpers::FormColumnHelpers
|
|
12
|
+
include ActiveScaffold::Helpers::SearchColumnHelpers
|
|
13
|
+
include ActiveScaffold::Helpers::CountryHelpers
|
|
14
|
+
include ActiveScaffold::Helpers::HumanConditionHelpers
|
|
15
|
+
|
|
16
|
+
##
|
|
17
|
+
## Delegates
|
|
18
|
+
##
|
|
19
|
+
|
|
20
|
+
# access to the configuration variable
|
|
21
|
+
def active_scaffold_config
|
|
22
|
+
controller.class.active_scaffold_config
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
def active_scaffold_config_for(*args)
|
|
26
|
+
controller.class.active_scaffold_config_for(*args)
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def active_scaffold_controller_for(*args)
|
|
30
|
+
controller.class.active_scaffold_controller_for(*args)
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
##
|
|
34
|
+
## Uncategorized
|
|
35
|
+
##
|
|
36
|
+
|
|
37
|
+
def generate_temporary_id
|
|
38
|
+
(Time.now.to_f*1000).to_i.to_s
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
# Turns [[label, value]] into <option> tags
|
|
42
|
+
# Takes optional parameter of :include_blank
|
|
43
|
+
def option_tags_for(select_options, options = {})
|
|
44
|
+
select_options.insert(0,[as_(:_select_),nil]) if options[:include_blank]
|
|
45
|
+
select_options.collect do |option|
|
|
46
|
+
label, value = option[0], option[1]
|
|
47
|
+
value.nil? ? "<option value="">#{label}</option>" : "<option value=\"#{value}\">#{label}</option>"
|
|
48
|
+
end
|
|
49
|
+
end
|
|
50
|
+
|
|
51
|
+
# Should this column be displayed in the subform?
|
|
52
|
+
def in_subform?(column, parent_record)
|
|
53
|
+
return true unless column.association
|
|
54
|
+
|
|
55
|
+
# Polymorphic associations can't appear because they *might* be the reverse association, and because you generally don't assign an association from the polymorphic side ... I think.
|
|
56
|
+
return false if column.polymorphic_association?
|
|
57
|
+
|
|
58
|
+
# A column shouldn't be in the subform if it's the reverse association to the parent
|
|
59
|
+
return false if column.association.reverse_for?(parent_record.class)
|
|
60
|
+
|
|
61
|
+
return true
|
|
62
|
+
end
|
|
63
|
+
|
|
64
|
+
def form_remote_upload_tag(url_for_options = {}, options = {})
|
|
65
|
+
options[:target] = action_iframe_id(url_for_options)
|
|
66
|
+
options[:multipart] ||= true
|
|
67
|
+
options[:class] = "#{options[:class]} as_remote_upload".strip
|
|
68
|
+
output=""
|
|
69
|
+
output << form_tag(url_for_options, options)
|
|
70
|
+
(output << "<iframe id='#{action_iframe_id(url_for_options)}' name='#{action_iframe_id(url_for_options)}' style='display:none'></iframe>").html_safe
|
|
71
|
+
end
|
|
72
|
+
|
|
73
|
+
# Provides list of javascripts to include with +javascript_include_tag+
|
|
74
|
+
# You can use this with your javascripts like
|
|
75
|
+
# <%= javascript_include_tag :defaults, 'your_own_cool_script', active_scaffold_javascripts, :cache => true %>
|
|
76
|
+
def active_scaffold_javascripts(frontend = :default)
|
|
77
|
+
ActiveScaffold::Config::Core.javascripts(frontend).collect do |name|
|
|
78
|
+
ActiveScaffold::Config::Core.asset_path(name, frontend)
|
|
79
|
+
end
|
|
80
|
+
end
|
|
81
|
+
|
|
82
|
+
# Provides stylesheets to include with +stylesheet_link_tag+
|
|
83
|
+
def active_scaffold_stylesheets(frontend = :default)
|
|
84
|
+
[ActiveScaffold::Config::Core.asset_path("stylesheet.css", frontend)]
|
|
85
|
+
end
|
|
86
|
+
|
|
87
|
+
# Provides stylesheets for IE to include with +stylesheet_link_tag+
|
|
88
|
+
def active_scaffold_ie_stylesheets(frontend = :default)
|
|
89
|
+
[ActiveScaffold::Config::Core.asset_path("stylesheet-ie.css", frontend)]
|
|
90
|
+
end
|
|
91
|
+
|
|
92
|
+
# easy way to include ActiveScaffold assets
|
|
93
|
+
def active_scaffold_includes(*args)
|
|
94
|
+
frontend = args.first.is_a?(Symbol) ? args.shift : :default
|
|
95
|
+
options = args.first.is_a?(Hash) ? args.shift : {}
|
|
96
|
+
js = javascript_include_tag(*active_scaffold_javascripts(frontend).push(options))
|
|
97
|
+
|
|
98
|
+
css = stylesheet_link_tag(*active_scaffold_stylesheets(frontend).push(options))
|
|
99
|
+
options[:cache] += '_ie' if options[:cache].is_a? String
|
|
100
|
+
options[:concat] += '_ie' if options[:concat].is_a? String
|
|
101
|
+
ie_css = stylesheet_link_tag(*active_scaffold_ie_stylesheets(frontend).push(options))
|
|
102
|
+
|
|
103
|
+
js + "\n" + css + "\n<!--[if IE]>".html_safe + ie_css + "<![endif]-->\n".html_safe
|
|
104
|
+
end
|
|
105
|
+
|
|
106
|
+
# a general-use loading indicator (the "stuff is happening, please wait" feedback)
|
|
107
|
+
def loading_indicator_tag(options)
|
|
108
|
+
image_tag "/images/active_scaffold/default/indicator.gif", :style => "visibility:hidden;", :id => loading_indicator_id(options), :alt => "loading indicator", :class => "loading-indicator"
|
|
109
|
+
end
|
|
110
|
+
|
|
111
|
+
# Creates a javascript-based link that toggles the visibility of some element on the page.
|
|
112
|
+
# By default, it toggles the visibility of the sibling after the one it's nested in. You may pass custom javascript logic in options[:of] to change that, though. For example, you could say :of => '$("my_div_id")'.
|
|
113
|
+
# You may also flag whether the other element is visible by default or not, and the initial text will adjust accordingly.
|
|
114
|
+
def link_to_visibility_toggle(id, options = {})
|
|
115
|
+
options[:default_visible] = true if options[:default_visible].nil?
|
|
116
|
+
options[:hide_label] = as_(:hide)
|
|
117
|
+
options[:show_label] = as_(:show)
|
|
118
|
+
javascript_tag("ActiveScaffold.create_visibility_toggle('#{id}', #{options.to_json});")
|
|
119
|
+
end
|
|
120
|
+
|
|
121
|
+
def skip_action_link(link, *args)
|
|
122
|
+
(!link.ignore_method.nil? and controller.try(link.ignore_method, *args)) || ((link.security_method_set? or controller.respond_to? link.security_method) and !controller.send(link.security_method, *args))
|
|
123
|
+
end
|
|
124
|
+
|
|
125
|
+
def render_action_link(link, url_options, record = nil, html_options = {})
|
|
126
|
+
url_options = action_link_url_options(link, url_options, record)
|
|
127
|
+
html_options = action_link_html_options(link, url_options, record, html_options)
|
|
128
|
+
action_link_html(link, url_options, html_options)
|
|
129
|
+
end
|
|
130
|
+
|
|
131
|
+
def action_link_url_options(link, url_options, record, options = {})
|
|
132
|
+
url_options = url_options.clone
|
|
133
|
+
url_options[:action] = link.action
|
|
134
|
+
url_options[:controller] = link.controller if link.controller
|
|
135
|
+
url_options.delete(:search) if link.controller and link.controller.to_s != params[:controller]
|
|
136
|
+
url_options.merge! link.parameters if link.parameters
|
|
137
|
+
url_options_for_nested_link(link.column, record, link, url_options, options) if link.nested_link?
|
|
138
|
+
url_options[:_method] = link.method if link.inline? && link.method != :get
|
|
139
|
+
url_options
|
|
140
|
+
end
|
|
141
|
+
|
|
142
|
+
def action_link_html_options(link, url_options, record, html_options)
|
|
143
|
+
link_id = get_action_link_id(url_options, record, link.column)
|
|
144
|
+
html_options.reverse_merge! link.html_options.merge(:class => link.action)
|
|
145
|
+
|
|
146
|
+
# Needs to be in html_options to as the adding _method to the url is no longer supported by Rails
|
|
147
|
+
html_options[:method] = link.method if !link.inline? && link.method != :get
|
|
148
|
+
|
|
149
|
+
html_options['data-confirm'] = link.confirm(record.try(:to_label)) if link.confirm?
|
|
150
|
+
html_options['data-position'] = link.position if link.position and link.inline?
|
|
151
|
+
html_options[:class] += ' as_action' if link.inline?
|
|
152
|
+
html_options[:popup] = true if link.popup?
|
|
153
|
+
html_options[:id] = link_id
|
|
154
|
+
html_options[:remote] = true unless link.page?
|
|
155
|
+
if link.dhtml_confirm?
|
|
156
|
+
html_options[:class] += ' as_action' if !link.inline?
|
|
157
|
+
html_options[:page_link] = 'true' if !link.inline?
|
|
158
|
+
html_options[:dhtml_confirm] = link.dhtml_confirm.value
|
|
159
|
+
html_options[:onclick] = link.dhtml_confirm.onclick_function(controller, link_id)
|
|
160
|
+
end
|
|
161
|
+
html_options[:class] += " #{link.html_options[:class]}" unless link.html_options[:class].blank?
|
|
162
|
+
html_options
|
|
163
|
+
end
|
|
164
|
+
def get_action_link_id(url_options, record = nil, column = nil)
|
|
165
|
+
id = url_options[:id] || url_options[:parent_id]
|
|
166
|
+
id = "#{column.association.name}-#{record.id}" if column && column.plural_association?
|
|
167
|
+
if record.try(column.association.name.to_sym).present?
|
|
168
|
+
id = "#{column.association.name}-#{record.send(column.association.name).id}"
|
|
169
|
+
else
|
|
170
|
+
id = "#{column.association.name}-#{record.id}" unless record.nil?
|
|
171
|
+
end if column && column.singular_association?
|
|
172
|
+
action_id = "#{id_from_controller(url_options[:controller]) + '-' if url_options[:parent_controller]}#{url_options[:action].to_s}"
|
|
173
|
+
action_link_id(action_id, id)
|
|
174
|
+
end
|
|
175
|
+
|
|
176
|
+
def action_link_html(link, url, html_options)
|
|
177
|
+
# issue 260, use url_options[:link] if it exists. This prevents DB data from being localized.
|
|
178
|
+
label = url.delete(:link) if url.is_a?(Hash)
|
|
179
|
+
label ||= link.label
|
|
180
|
+
if link.image.nil?
|
|
181
|
+
html = link_to(label, url, html_options)
|
|
182
|
+
else
|
|
183
|
+
html = link_to(image_tag(link.image[:name] , :size => link.image[:size], :alt => label), url, html_options)
|
|
184
|
+
end
|
|
185
|
+
# if url is nil we would like to generate an anchor without href attribute
|
|
186
|
+
url.nil? ? html.sub(/href=".*?"/, '') : html
|
|
187
|
+
end
|
|
188
|
+
|
|
189
|
+
def url_options_for_nested_link(column, record, link, url_options, options = {})
|
|
190
|
+
if column && column.association
|
|
191
|
+
url_options[:assoc_id] = url_options.delete(:id)
|
|
192
|
+
url_options[:id] = record.send(column.association.name).id if column.singular_association? && record.send(column.association.name).present?
|
|
193
|
+
link.eid = "#{controller_id.from(3)}_#{record.id}_#{column.association.name}" unless options.has_key?(:reuse_eid)
|
|
194
|
+
url_options[:eid] = link.eid
|
|
195
|
+
elsif link.parameters && link.parameters[:named_scope]
|
|
196
|
+
url_options[:assoc_id] = url_options.delete(:id)
|
|
197
|
+
link.eid = "#{controller_id.from(3)}_#{record.id}_#{link.parameters[:named_scope]}" unless options.has_key?(:reuse_eid)
|
|
198
|
+
url_options[:eid] = link.eid
|
|
199
|
+
end
|
|
200
|
+
end
|
|
201
|
+
|
|
202
|
+
def column_class(column, column_value, record)
|
|
203
|
+
classes = []
|
|
204
|
+
classes << "#{column.name}-column"
|
|
205
|
+
if column.css_class.is_a?(Proc)
|
|
206
|
+
css_class = column.css_class.call(column_value, record)
|
|
207
|
+
classes << css_class unless css_class.nil?
|
|
208
|
+
else
|
|
209
|
+
classes << column.css_class
|
|
210
|
+
end unless column.css_class.nil?
|
|
211
|
+
|
|
212
|
+
classes << 'empty' if column_empty? column_value
|
|
213
|
+
classes << 'sorted' if active_scaffold_config.list.user.sorting.sorts_on?(column)
|
|
214
|
+
classes << 'numeric' if column.column and [:decimal, :float, :integer].include?(column.column.type)
|
|
215
|
+
classes.join(' ')
|
|
216
|
+
end
|
|
217
|
+
|
|
218
|
+
def column_heading_class(column, sorting)
|
|
219
|
+
classes = []
|
|
220
|
+
classes << "#{column.name}-column_heading"
|
|
221
|
+
classes << "sorted #{sorting.direction_of(column).downcase}" if sorting.sorts_on? column
|
|
222
|
+
classes << column.css_class unless column.css_class.nil?
|
|
223
|
+
classes.join(' ')
|
|
224
|
+
end
|
|
225
|
+
|
|
226
|
+
def column_empty?(column_value)
|
|
227
|
+
empty = column_value.nil?
|
|
228
|
+
empty ||= column_value.empty? if column_value.respond_to? :empty?
|
|
229
|
+
empty ||= [' ', active_scaffold_config.list.empty_field_text].include? column_value if String === column_value
|
|
230
|
+
return empty
|
|
231
|
+
end
|
|
232
|
+
|
|
233
|
+
def column_calculation(column)
|
|
234
|
+
conditions = controller.send(:all_conditions)
|
|
235
|
+
includes = active_scaffold_config.list.count_includes
|
|
236
|
+
includes ||= controller.send(:active_scaffold_includes) unless conditions.nil?
|
|
237
|
+
calculation = beginning_of_chain.calculate(column.calculate, column.name, :conditions => conditions,
|
|
238
|
+
:joins => controller.send(:joins_for_collection), :include => includes)
|
|
239
|
+
end
|
|
240
|
+
|
|
241
|
+
def render_column_calculation(column)
|
|
242
|
+
calculation = column_calculation(column)
|
|
243
|
+
override_formatter = "render_#{column.name}_#{column.calculate}"
|
|
244
|
+
calculation = send(override_formatter, calculation) if respond_to? override_formatter
|
|
245
|
+
|
|
246
|
+
"#{as_(column.calculate)}: #{format_column_value nil, column, calculation}"
|
|
247
|
+
end
|
|
248
|
+
|
|
249
|
+
def column_show_add_existing(column)
|
|
250
|
+
(column.allow_add_existing and options_for_association_count(column.association) > 0)
|
|
251
|
+
end
|
|
252
|
+
|
|
253
|
+
def column_show_add_new(column, associated, record)
|
|
254
|
+
value = column.plural_association? || (column.singular_association? and not associated.empty?)
|
|
255
|
+
value = false unless record.class.authorized_for?(:crud_type => :create)
|
|
256
|
+
value
|
|
257
|
+
end
|
|
258
|
+
|
|
259
|
+
def error_messages_for(*params)
|
|
260
|
+
options = params.extract_options!.symbolize_keys
|
|
261
|
+
|
|
262
|
+
objects = Array.wrap(options.delete(:object) || params).map do |object|
|
|
263
|
+
object = instance_variable_get("@#{object}") unless object.respond_to?(:to_model)
|
|
264
|
+
object = convert_to_model(object)
|
|
265
|
+
|
|
266
|
+
if object.class.respond_to?(:model_name)
|
|
267
|
+
options[:object_name] ||= object.class.model_name.human.downcase
|
|
268
|
+
end
|
|
269
|
+
|
|
270
|
+
object
|
|
271
|
+
end
|
|
272
|
+
|
|
273
|
+
objects.compact!
|
|
274
|
+
count = objects.inject(0) {|sum, object| sum + object.errors.count }
|
|
275
|
+
|
|
276
|
+
unless count.zero?
|
|
277
|
+
html = {}
|
|
278
|
+
[:id, :class].each do |key|
|
|
279
|
+
if options.include?(key)
|
|
280
|
+
value = options[key]
|
|
281
|
+
html[key] = value unless value.blank?
|
|
282
|
+
else
|
|
283
|
+
html[key] = 'errorExplanation'
|
|
284
|
+
end
|
|
285
|
+
end
|
|
286
|
+
options[:object_name] ||= params.first
|
|
287
|
+
|
|
288
|
+
header_message = if options.include?(:header_message)
|
|
289
|
+
options[:header_message]
|
|
290
|
+
else
|
|
291
|
+
as_('errors.template.header', :count => count, :model => options[:object_name].to_s.gsub('_', ' '))
|
|
292
|
+
end
|
|
293
|
+
|
|
294
|
+
message = options.include?(:message) ? options[:message] : as_('errors.template.body')
|
|
295
|
+
|
|
296
|
+
error_messages = objects.sum do |object|
|
|
297
|
+
object.errors.full_messages.map do |msg|
|
|
298
|
+
content_tag(:li, msg)
|
|
299
|
+
end
|
|
300
|
+
end.join.html_safe
|
|
301
|
+
|
|
302
|
+
contents = ''
|
|
303
|
+
contents << content_tag(options[:header_tag] || :h2, header_message) unless header_message.blank?
|
|
304
|
+
contents << content_tag(:p, message) unless message.blank?
|
|
305
|
+
contents << content_tag(:ul, error_messages)
|
|
306
|
+
|
|
307
|
+
content_tag(:div, contents.html_safe, html)
|
|
308
|
+
|
|
309
|
+
else
|
|
310
|
+
''
|
|
311
|
+
end
|
|
312
|
+
end
|
|
313
|
+
end
|
|
314
|
+
end
|
|
315
|
+
end
|