ab_admin 0.3.6 → 0.4.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/{LICENSE.txt → MIT-LICENSE} +2 -4
- data/README.md +3 -3
- data/Rakefile +21 -3
- data/app/assets/images/admin/flags/b_de.png +0 -0
- data/app/assets/images/admin/flags/b_es.png +0 -0
- data/app/assets/images/admin/flags/b_fr.png +0 -0
- data/app/assets/images/admin/flags/flag_de.gif +0 -0
- data/app/assets/images/admin/flags/flag_de_nonact.gif +0 -0
- data/app/assets/images/admin/flags/flag_es.gif +0 -0
- data/app/assets/images/admin/flags/flag_es_nonact.gif +0 -0
- data/app/assets/images/admin/flags/flag_fr.gif +0 -0
- data/app/assets/images/admin/flags/flag_fr_nonact.gif +0 -0
- data/app/assets/javascripts/ab_admin/components/admin_assets.js.coffee +50 -60
- data/app/assets/javascripts/ab_admin/components/base_assets.js.coffee +86 -0
- data/app/assets/javascripts/ab_admin/components/croppable_image.js.coffee +4 -4
- data/app/assets/javascripts/ab_admin/components/gmaps.js.coffee +5 -0
- data/app/assets/javascripts/ab_admin/components/google_translate.js.coffee +0 -1
- data/app/assets/javascripts/ab_admin/components/in_place_edit.js.coffee +7 -3
- data/app/assets/javascripts/ab_admin/components/locator.js.coffee +1 -1
- data/app/assets/javascripts/ab_admin/components/select2_bridge.js.coffee +152 -0
- data/app/assets/javascripts/ab_admin/components/sortable_tree.js.coffee +1 -1
- data/app/assets/javascripts/ab_admin/core/batch_actions.js.coffee +5 -4
- data/app/assets/javascripts/ab_admin/core/columns_hider.js.coffee +4 -11
- data/app/assets/javascripts/ab_admin/core/confirmation.js.coffee +4 -43
- data/app/assets/javascripts/ab_admin/core/deprecated_utils.js.coffee +44 -0
- data/app/assets/javascripts/ab_admin/core/init.js.coffee +8 -25
- data/app/assets/javascripts/ab_admin/core/pjax.js.coffee +18 -4
- data/app/assets/javascripts/ab_admin/core/search_form.js.coffee +5 -5
- data/app/assets/javascripts/ab_admin/core/ui_utils.js.coffee +15 -86
- data/app/assets/javascripts/ab_admin/core/utils.js.coffee +38 -51
- data/app/assets/javascripts/ab_admin/core/view_layout.js.coffee +1 -1
- data/app/assets/javascripts/ab_admin/inputs/datetime_input.js.coffee +16 -18
- data/app/assets/javascripts/ab_admin/main.js +7 -7
- data/app/assets/stylesheets/ab_admin/bootstrap_and_overrides.css.scss +21 -8
- data/app/assets/stylesheets/ab_admin/components/_admin_comments.css.scss +17 -5
- data/app/assets/stylesheets/ab_admin/components/_base.css.scss +4 -0
- data/app/assets/stylesheets/ab_admin/components/_colored_tabs.css.scss +1 -4
- data/app/assets/stylesheets/ab_admin/components/_columns_hider.css.scss +5 -0
- data/app/assets/stylesheets/ab_admin/components/_form.css.scss +45 -16
- data/app/assets/stylesheets/ab_admin/components/_grid_view.css.scss +11 -0
- data/app/assets/stylesheets/ab_admin/components/_locale_tabs.css.scss +1 -1
- data/app/assets/stylesheets/ab_admin/components/_navigation.css.scss +11 -9
- data/app/assets/stylesheets/ab_admin/components/_table_view.css.scss +1 -1
- data/app/assets/stylesheets/ab_admin/components/_translations.css.scss +1 -0
- data/app/assets/stylesheets/ab_admin/components/{_sortable_tree.css.scss → _tree_view.css.scss} +8 -3
- data/app/assets/stylesheets/ab_admin/fileupload.css.scss +51 -43
- data/app/assets/stylesheets/ab_admin/main.css.scss +1 -3
- data/app/controllers/admin/admin_comments_controller.rb +14 -4
- data/app/controllers/admin/assets_controller.rb +44 -35
- data/app/controllers/admin/base_controller.rb +93 -38
- data/app/controllers/admin/locators_controller.rb +3 -2
- data/app/controllers/admin/manager_controller.rb +20 -9
- data/app/controllers/admin/structures_controller.rb +9 -1
- data/app/controllers/admin/users_controller.rb +1 -2
- data/app/views/ab_admin/devise/sessions/new.html.slim +1 -1
- data/app/views/admin/admin_comments/_comment.html.slim +21 -7
- data/app/views/admin/admin_comments/_comments.html.slim +1 -1
- data/app/views/admin/admin_comments/_form.html.slim +8 -3
- data/app/views/admin/admin_comments/_list_block.html.slim +7 -0
- data/app/views/admin/admin_comments/create.js.erb +3 -2
- data/app/views/admin/admin_comments/destroy.js.erb +1 -1
- data/app/views/admin/admin_comments/index.js.erb +14 -0
- data/app/views/admin/assets/batch_edit.html.slim +14 -0
- data/app/views/admin/base/_modal_form_layout.html.slim +12 -0
- data/app/views/admin/base/_search_layout.html.slim +4 -3
- data/app/views/admin/base/_table.html.slim +2 -2
- data/app/views/admin/base/create.js.erb +13 -8
- data/app/views/admin/base/history.html.slim +18 -0
- data/app/views/admin/base/index.html.slim +3 -3
- data/app/views/admin/base/new.js.erb +14 -8
- data/app/views/admin/base/show.html.slim +1 -2
- data/app/views/admin/base/show.js.erb +7 -0
- data/app/views/admin/fileupload/_asset_templates.html.slim +29 -0
- data/app/views/admin/fileupload/_container.html.slim +13 -12
- data/app/views/admin/fileupload/_file.html.slim +2 -2
- data/app/views/admin/fileupload/_image.html.slim +8 -0
- data/app/views/admin/fileupload/_video.html.slim +2 -2
- data/app/views/admin/headers/_form.html.slim +2 -0
- data/app/views/admin/locators/edit.html.slim +1 -1
- data/app/views/admin/locators/show.html.slim +1 -2
- data/app/views/admin/manager/_form.html.slim +17 -3
- data/app/views/admin/manager/_modal_form.html.slim +19 -0
- data/app/views/admin/manager/_table.html.slim +3 -3
- data/app/views/admin/manager/show.html.slim +1 -0
- data/app/views/admin/shared/_content_actions.html.slim +39 -0
- data/app/views/admin/shared/_locale_tabs.html.slim +3 -3
- data/app/views/admin/shared/inputs/_checkbox_tree.html.slim +9 -3
- data/app/views/admin/structures/_form.html.slim +4 -7
- data/app/views/admin/users/_form.html.slim +2 -4
- data/app/views/admin/users/_search_form.html.slim +0 -1
- data/app/views/admin/users/_table.html.slim +8 -10
- data/app/views/layouts/admin/_footer.html.slim +3 -4
- data/app/views/layouts/admin/_navigation.html.slim +2 -2
- data/app/views/layouts/admin/application.html.slim +7 -9
- data/app/views/layouts/admin/devise.html.slim +3 -4
- data/config/locales/de.yml +319 -0
- data/config/locales/en.devise.yml +44 -31
- data/config/locales/en.yml +166 -143
- data/config/locales/it.devise.yml +54 -41
- data/config/locales/it.yml +178 -163
- data/config/locales/ru.devise.yml +70 -56
- data/config/locales/ru.yml +280 -264
- data/config/routes.rb +6 -3
- data/db/migrate/20130101000001_create_users.rb +7 -11
- data/db/migrate/20130101000003_create_assets.rb +5 -5
- data/db/migrate/20130101000004_create_headers.rb +2 -6
- data/db/migrate/20130101000005_create_static_pages.rb +1 -5
- data/db/migrate/20130101000006_create_structures.rb +5 -9
- data/db/migrate/20130101000007_base_translations.rb +3 -1
- data/db/migrate/20130101000008_create_admin_comments.rb +5 -5
- data/db/migrate/20130101000009_create_tracks.rb +20 -0
- data/lib/ab_admin.rb +36 -4
- data/lib/ab_admin/abstract_resource.rb +28 -7
- data/lib/ab_admin/carrierwave/base_uploader.rb +85 -5
- data/lib/ab_admin/carrierwave/glue.rb +6 -1
- data/lib/ab_admin/concerns/admin_addition.rb +26 -9
- data/lib/ab_admin/concerns/asset_human_names.rb +23 -0
- data/lib/ab_admin/concerns/fileuploads.rb +102 -0
- data/lib/ab_admin/concerns/has_tracking.rb +32 -0
- data/lib/ab_admin/concerns/nested_set.rb +9 -9
- data/lib/ab_admin/concerns/silencer.rb +5 -5
- data/lib/ab_admin/concerns/utilities.rb +28 -16
- data/lib/ab_admin/concerns/validations.rb +1 -1
- data/lib/ab_admin/config/base.rb +10 -2
- data/lib/ab_admin/controllers/callbacks.rb +2 -2
- data/lib/ab_admin/controllers/can_can_manager_resource.rb +3 -2
- data/lib/ab_admin/controllers/fv.rb +16 -0
- data/lib/ab_admin/controllers/head_options.rb +6 -4
- data/lib/ab_admin/core_ext/hash.rb +25 -70
- data/lib/ab_admin/core_ext/string.rb +17 -4
- data/lib/ab_admin/engine.rb +2 -8
- data/lib/ab_admin/hooks.rb +8 -3
- data/lib/ab_admin/hooks/active_model_hooks.rb +1 -1
- data/lib/ab_admin/hooks/globalize_hooks.rb +35 -0
- data/lib/ab_admin/hooks/paginate_hooks.rb +3 -1
- data/lib/ab_admin/i18n_tools/model_translator.rb +1 -1
- data/lib/ab_admin/menu/abstract_builder.rb +14 -0
- data/lib/ab_admin/menu/base_group.rb +26 -0
- data/lib/ab_admin/menu/builder.rb +16 -0
- data/lib/ab_admin/menu/group.rb +24 -0
- data/lib/ab_admin/menu/item.rb +23 -0
- data/lib/ab_admin/models/admin_comment.rb +68 -0
- data/lib/ab_admin/models/asset.rb +30 -19
- data/lib/ab_admin/models/attachment_file.rb +2 -1
- data/lib/ab_admin/models/header.rb +15 -0
- data/lib/ab_admin/models/locator.rb +1 -3
- data/lib/ab_admin/models/settings.rb +10 -10
- data/lib/ab_admin/models/structure.rb +20 -9
- data/lib/ab_admin/models/track.rb +61 -0
- data/lib/ab_admin/models/type_model.rb +30 -17
- data/lib/ab_admin/models/user.rb +18 -49
- data/lib/ab_admin/utils.rb +16 -7
- data/lib/ab_admin/utils/logger.rb +11 -7
- data/lib/ab_admin/utils/mysql.rb +10 -0
- data/lib/ab_admin/version.rb +1 -1
- data/lib/ab_admin/views/admin_helpers.rb +20 -9
- data/lib/ab_admin/views/admin_navigation_helpers.rb +44 -21
- data/lib/ab_admin/views/content_only_wrapper.rb +14 -0
- data/lib/ab_admin/views/form_builder.rb +27 -89
- data/lib/ab_admin/views/helpers.rb +1 -28
- data/lib/ab_admin/views/inputs/capture_block_input.rb +16 -0
- data/lib/ab_admin/views/inputs/date_time_picker_input.rb +45 -0
- data/lib/ab_admin/views/inputs/token_input.rb +2 -1
- data/lib/ab_admin/views/inputs/uploader_input.rb +101 -0
- data/lib/ab_admin/views/manager_helpers.rb +12 -0
- data/lib/ab_admin/views/search_form_builder.rb +36 -13
- data/lib/generators/ab_admin/ckeditor_assets/ckeditor_assets_generator.rb +1 -1
- data/lib/generators/ab_admin/install/install_generator.rb +3 -2
- data/lib/generators/ab_admin/install/templates/config/ab_admin.rb.erb +1 -1
- data/lib/generators/ab_admin/install/templates/config/admin_menu.rb +1 -1
- data/lib/generators/ab_admin/install/templates/config/i18n-js.yml +1 -1
- data/lib/generators/ab_admin/install/templates/config/nginx.conf +22 -9
- data/lib/generators/ab_admin/install/templates/config/robots.txt +7 -0
- data/lib/generators/ab_admin/install/templates/config/seeds.rb +2 -1
- data/lib/generators/ab_admin/install/templates/models/ability.rb +2 -7
- data/lib/generators/ab_admin/install/templates/models/admin_comment.rb +3 -28
- data/lib/generators/ab_admin/install/templates/models/asset.rb +4 -2
- data/lib/generators/ab_admin/install/templates/models/attachment_file.rb +1 -1
- data/lib/generators/ab_admin/install/templates/models/avatar.rb +2 -2
- data/lib/generators/ab_admin/install/templates/models/gender_type.rb +1 -1
- data/lib/generators/ab_admin/install/templates/models/header.rb +2 -2
- data/lib/generators/ab_admin/install/templates/models/locator.rb +0 -1
- data/lib/generators/ab_admin/install/templates/models/picture.rb +1 -1
- data/lib/generators/ab_admin/install/templates/models/settings.rb +1 -1
- data/lib/generators/ab_admin/install/templates/models/structure.rb +6 -8
- data/lib/generators/ab_admin/install/templates/models/track.rb +5 -0
- data/lib/generators/ab_admin/install/templates/models/user.rb +2 -3
- data/lib/generators/ab_admin/install/templates/script/unicorn.sh +0 -2
- data/lib/generators/ab_admin/install/templates/spec/factories/user_factory.rb +1 -2
- data/lib/generators/ab_admin/install/templates/uploaders/attachment_file_uploader.rb +1 -1
- data/lib/generators/ab_admin/install/templates/uploaders/avatar_uploader.rb +1 -1
- data/lib/generators/ab_admin/install/templates/uploaders/picture_uploader.rb +1 -1
- data/lib/generators/ab_admin/model/templates/resource.erb +1 -1
- data/lib/generators/ab_admin/resource/templates/_form.slim.erb +49 -45
- data/lib/generators/ab_admin/resource/templates/_table.slim.erb +1 -1
- data/lib/generators/template.rb +32 -56
- data/lib/tasks/assets.rake +1 -0
- metadata +197 -698
- data/.gitignore +0 -41
- data/Gemfile +0 -77
- data/Guardfile +0 -35
- data/TODO +0 -4
- data/ab_admin.gemspec +0 -59
- data/app/views/admin/fileupload/_asset.html.slim +0 -8
- data/app/views/admin/fileupload/_ftmpl.html.slim +0 -6
- data/app/views/admin/fileupload/_tmpl.html.slim +0 -9
- data/app/views/admin/fileupload/_vtmpl.html.slim +0 -10
- data/app/views/admin/shared/_batch_actions.html.slim +0 -27
- data/cucumber.yml +0 -10
- data/features/dsl/action_items.feature +0 -79
- data/features/dsl/admin_comments.feature +0 -30
- data/features/dsl/batch_actions.feature +0 -69
- data/features/dsl/config.feature +0 -44
- data/features/dsl/custom_actions.feature +0 -62
- data/features/dsl/export.feature +0 -42
- data/features/dsl/form.feature +0 -77
- data/features/dsl/in_place_edit.feature +0 -26
- data/features/dsl/list_edit.feature +0 -46
- data/features/dsl/parent_resource.feature +0 -18
- data/features/dsl/resource_action_items.feature +0 -40
- data/features/dsl/search.feature +0 -41
- data/features/dsl/show.feature +0 -37
- data/features/dsl/table.feature +0 -71
- data/features/dsl/tree.feature +0 -37
- data/features/index_views/table.feature +0 -20
- data/features/locators.feature +0 -40
- data/features/menu.feature +0 -35
- data/features/settings.feature +0 -36
- data/features/step_definitions/configuration_steps.rb +0 -94
- data/features/step_definitions/dsl/action_items_steps.rb +0 -13
- data/features/step_definitions/dsl/admin_comments_steps.rb +0 -12
- data/features/step_definitions/dsl/batch_actions_steps.rb +0 -27
- data/features/step_definitions/dsl/in_place_edit_steps.rb +0 -7
- data/features/step_definitions/dsl/parent_resource_steps.rb +0 -8
- data/features/step_definitions/dsl/resource_action_items_steps.rb +0 -14
- data/features/step_definitions/dsl/show_steps.rb +0 -8
- data/features/step_definitions/dsl/table_steps.rb +0 -38
- data/features/step_definitions/dsl/tree_steps.rb +0 -28
- data/features/step_definitions/menu_steps.rb +0 -20
- data/features/step_definitions/settings_steps.rb +0 -7
- data/features/step_definitions/structure_steps.rb +0 -7
- data/features/step_definitions/table_steps.rb +0 -23
- data/features/step_definitions/user_steps.rb +0 -72
- data/features/step_definitions/web_steps/browsing_steps.rb +0 -108
- data/features/step_definitions/web_steps/debug_steps.rb +0 -6
- data/features/step_definitions/web_steps/form_steps.rb +0 -190
- data/features/step_definitions/web_steps/i18n_steps.rb +0 -8
- data/features/step_definitions/web_steps/step_scoper.rb +0 -9
- data/features/step_definitions/web_steps/transforms_steps.rb +0 -3
- data/features/structure/tree.feature +0 -21
- data/features/support/capybara_helpers.rb +0 -15
- data/features/support/carrierwave.rb +0 -21
- data/features/support/env.rb +0 -40
- data/features/support/paths.rb +0 -55
- data/features/support/selector_helpers.rb +0 -9
- data/features/support/selectors.rb +0 -43
- data/features/support/tolerance_for_selenium_sync_issues.rb +0 -27
- data/features/user/sign_in.feature +0 -27
- data/features/user/sign_out.feature +0 -11
- data/features/user/user_edit.feature +0 -19
- data/features/user/user_show.feature +0 -9
- data/lib/ab_admin/hooks/quiet_scope_page.rb +0 -16
- data/lib/ab_admin/hooks/simple_form_hooks.rb +0 -31
- data/lib/ab_admin/menu_builder.rb +0 -89
- data/lib/ab_admin/views/inputs/date_time_input.rb +0 -65
- data/lib/generators/ab_admin/install/templates/models/user_state.rb +0 -6
- data/lib/generators/ab_admin/resource/templates/_form.haml.erb +0 -71
- data/lib/generators/ab_admin/resource/templates/_search_form.haml.erb +0 -35
- data/lib/generators/ab_admin/resource/templates/_table.haml.erb +0 -33
- data/spec/ab_admin_spec.rb +0 -23
- data/spec/dummy/Rakefile +0 -7
- data/spec/dummy/app/assets/images/rails.png +0 -0
- data/spec/dummy/app/assets/javascripts/application.js +0 -15
- data/spec/dummy/app/assets/stylesheets/application.css +0 -13
- data/spec/dummy/app/controllers/application_controller.rb +0 -3
- data/spec/dummy/app/controllers/products_controller.rb +0 -5
- data/spec/dummy/app/controllers/welcome_controller.rb +0 -5
- data/spec/dummy/app/mailers/.gitkeep +0 -0
- data/spec/dummy/app/models/ab_admin/ab_admin_catalogue.rb +0 -5
- data/spec/dummy/app/models/ab_admin/ab_admin_collection.rb +0 -35
- data/spec/dummy/app/models/ab_admin/ab_admin_product.rb +0 -74
- data/spec/dummy/app/models/admin_menu.rb +0 -18
- data/spec/dummy/app/models/catalogue.rb +0 -10
- data/spec/dummy/app/models/ckeditor/asset.rb +0 -7
- data/spec/dummy/app/models/ckeditor/attachment_file.rb +0 -7
- data/spec/dummy/app/models/ckeditor/picture.rb +0 -7
- data/spec/dummy/app/models/collection.rb +0 -20
- data/spec/dummy/app/models/product.rb +0 -32
- data/spec/dummy/app/uploaders/ckeditor_attachment_file_uploader.rb +0 -42
- data/spec/dummy/app/uploaders/ckeditor_picture_uploader.rb +0 -53
- data/spec/dummy/app/views/admin/collections/_form.html.slim +0 -24
- data/spec/dummy/app/views/layouts/application.html.erb +0 -14
- data/spec/dummy/app/views/products/show.html.erb +0 -2
- data/spec/dummy/app/views/welcome/index.html.erb +0 -2
- data/spec/dummy/config.ru +0 -4
- data/spec/dummy/config/application.rb +0 -82
- data/spec/dummy/config/boot.rb +0 -10
- data/spec/dummy/config/database.yml +0 -26
- data/spec/dummy/config/environment.rb +0 -5
- data/spec/dummy/config/environments/development.rb +0 -37
- data/spec/dummy/config/environments/production.rb +0 -67
- data/spec/dummy/config/environments/test.rb +0 -37
- data/spec/dummy/config/i18n-js.yml +0 -21
- data/spec/dummy/config/initializers/ab_admin.rb +0 -15
- data/spec/dummy/config/initializers/backtrace_silencers.rb +0 -7
- data/spec/dummy/config/initializers/ckeditor.rb +0 -18
- data/spec/dummy/config/initializers/devise.rb +0 -232
- data/spec/dummy/config/initializers/inflections.rb +0 -15
- data/spec/dummy/config/initializers/mime_types.rb +0 -5
- data/spec/dummy/config/initializers/secret_token.rb +0 -7
- data/spec/dummy/config/initializers/session_store.rb +0 -8
- data/spec/dummy/config/initializers/simple_form.rb +0 -142
- data/spec/dummy/config/initializers/simple_form_bootstrap.rb +0 -45
- data/spec/dummy/config/initializers/wrap_parameters.rb +0 -14
- data/spec/dummy/config/locales/devise.en.yml +0 -60
- data/spec/dummy/config/locales/en.yml +0 -5
- data/spec/dummy/config/locales/simple_form.en.yml +0 -26
- data/spec/dummy/config/routes.rb +0 -14
- data/spec/dummy/config/settings/development.local.yml +0 -9
- data/spec/dummy/config/settings/development.yml +0 -7
- data/spec/dummy/db/migrate/20130129151853_create_ckeditor_assets.rb +0 -26
- data/spec/dummy/db/migrate/20130130161853_create_collections.rb +0 -10
- data/spec/dummy/db/migrate/20130130162046_create_products.rb +0 -13
- data/spec/dummy/db/migrate/20130130175446_create_globalize_collection_product.rb +0 -11
- data/spec/dummy/db/migrate/20130207224516_create_catalogues.rb +0 -16
- data/spec/dummy/db/migrate/20130209223506_add_lat_lon_zoom_to_products.rb +0 -7
- data/spec/dummy/db/seeds.rb +0 -46
- data/spec/dummy/lib/assets/.gitkeep +0 -0
- data/spec/dummy/lib/capybara_irb.rb +0 -42
- data/spec/dummy/lib/tasks/.gitkeep +0 -0
- data/spec/dummy/lib/tasks/cucumber.rake +0 -65
- data/spec/dummy/lib/templates/slim/scaffold/_form.html.slim +0 -10
- data/spec/dummy/log/.gitkeep +0 -0
- data/spec/dummy/public/404.html +0 -26
- data/spec/dummy/public/422.html +0 -26
- data/spec/dummy/public/500.html +0 -25
- data/spec/dummy/public/favicon.ico +0 -0
- data/spec/dummy/script/cucumber +0 -10
- data/spec/dummy/script/rails +0 -6
- data/spec/factories/assets.rb +0 -52
- data/spec/factories/catalogues.rb +0 -7
- data/spec/factories/collections.rb +0 -8
- data/spec/factories/files/rails.png +0 -0
- data/spec/factories/products.rb +0 -17
- data/spec/factories/sequences.rb +0 -7
- data/spec/factories/structures.rb +0 -17
- data/spec/factories/users.rb +0 -30
- data/spec/generators/ckeditor_assets_generator_spec.rb +0 -19
- data/spec/generators/install_generator_spec.rb +0 -48
- data/spec/generators/model_generator_spec.rb +0 -31
- data/spec/generators/resource_generator_spec.rb +0 -36
- data/spec/models/ab_admin/abstract_resource_spec.rb +0 -5
- data/spec/models/avatar_spec.rb +0 -162
- data/spec/models/picture_uploader_spec.rb +0 -49
- data/spec/models/structure_spec.rb +0 -69
- data/spec/models/user_spec.rb +0 -159
- data/spec/shared_behaviors/concerns.rb +0 -20
- data/spec/spec_helper.rb +0 -96
- data/spec/support/controller_macros.rb +0 -52
- data/spec/support/custom_capybara_matchers.rb +0 -58
- data/spec/support/mailer_macros.rb +0 -17
- data/spec/support/shared_connection.rb +0 -11
- data/vendor/assets/images/ab_admin/clear.png +0 -0
- data/vendor/assets/images/ab_admin/loading.gif +0 -0
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/core.js +0 -899
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/index.js +0 -2
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.bg.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.br.js +0 -13
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.cs.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.da.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.de.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.es.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.fi.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.fr.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.id.js +0 -13
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.is.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.it.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.ja.js +0 -13
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.kr.js +0 -13
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.lt.js +0 -15
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.lv.js +0 -16
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.ms.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.nb.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.nl.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.pl.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.pt-BR.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.pt.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.ro.js +0 -15
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.ru.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.sk.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.sl.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.sv.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.th.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.tr.js +0 -15
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.zh-CN.js +0 -14
- data/vendor/assets/javascripts/ab_admin/bootstrap-datepicker/locales/bootstrap-datepicker.zh-TW.js +0 -13
- data/vendor/assets/javascripts/ab_admin/bootstrap-editable-inline.js +0 -2895
- data/vendor/assets/javascripts/ab_admin/bootstrap-editable.js +0 -4523
- data/vendor/assets/javascripts/ab_admin/bootstrap-tab-multi.js +0 -135
- data/vendor/assets/javascripts/ab_admin/bootstrap-timepicker.js +0 -377
- data/vendor/assets/javascripts/ab_admin/fileupload/admin-fileuploader.js.coffee +0 -111
- data/vendor/assets/javascripts/ab_admin/fileupload/fileuploader.js +0 -1301
- data/vendor/assets/javascripts/ab_admin/jquery.Jcrop.js +0 -1083
- data/vendor/assets/javascripts/ab_admin/jquery_nested_form.js.coffee +0 -66
- data/vendor/assets/javascripts/bootstrap-wysihtml5/locales/ru.js +0 -48
- data/vendor/assets/javascripts/handlebars.min.js +0 -1
- data/vendor/assets/javascripts/jquery.cookie.js +0 -42
- data/vendor/assets/javascripts/jquery.hotkeys.js +0 -106
- data/vendor/assets/javascripts/jquery.pjax.js +0 -688
- data/vendor/assets/javascripts/jquery.tmpl.min.js +0 -10
- data/vendor/assets/javascripts/jquery.ui.nestedSortable.js +0 -356
- data/vendor/assets/javascripts/jquery/jquery-ui.min.js +0 -15
- data/vendor/assets/javascripts/jquery/jquery.min.js +0 -4
- data/vendor/assets/javascripts/underscore.min.js +0 -5
- data/vendor/assets/stylesheets/ab_admin/bootstrap-datepicker.css.scss +0 -274
- data/vendor/assets/stylesheets/ab_admin/bootstrap-editable.scss +0 -461
- data/vendor/assets/stylesheets/ab_admin/bootstrap-timepicker.css.scss +0 -88
- data/vendor/assets/stylesheets/ab_admin/jquery.Jcrop.min.css.scss +0 -28
@@ -11,35 +11,38 @@ module AbAdmin
|
|
11
11
|
map_type :color, to: ::AbAdmin::Views::Inputs::ColorInput
|
12
12
|
map_type :ckeditor, to: ::AbAdmin::Views::Inputs::CkeditorInput
|
13
13
|
map_type :editor, to: ::AbAdmin::Views::Inputs::EditorInput
|
14
|
-
map_type :
|
14
|
+
map_type :date_picker, :time_picker, :datetime_picker, to: ::AbAdmin::Views::Inputs::DateTimePickerInput
|
15
15
|
map_type :token, to: ::AbAdmin::Views::Inputs::TokenInput
|
16
|
+
map_type :capture_block, to: ::AbAdmin::Views::Inputs::CaptureBlockInput
|
17
|
+
map_type :uploader, to: ::AbAdmin::Views::Inputs::UploaderInput
|
16
18
|
|
17
19
|
def input(attribute_name, options = {}, &block)
|
18
|
-
|
20
|
+
options[:collection] = options[:collection].call if options[:collection].is_a?(Proc)
|
21
|
+
|
22
|
+
is_select = options[:as].nil? || options[:as] == :select
|
23
|
+
is_large_collection = options[:collection] && options[:collection].to_a.length > 30
|
24
|
+
if options[:fancy] || (is_select && is_large_collection)
|
19
25
|
options[:input_html] ||= {}
|
20
26
|
options[:input_html][:class] = "#{options[:input_html][:class]} fancy_select"
|
21
27
|
end
|
22
28
|
|
29
|
+
if options[:append]
|
30
|
+
return super(attribute_name, options.merge(wrapper: 'append')) do
|
31
|
+
input_field(attribute_name, options.merge(options[:input_html] || {})) + %(<span class="add-on #{options[:append_class]}">#{options[:append]}</span>).html_safe
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
23
35
|
case options[:as]
|
24
|
-
when :uploader
|
25
|
-
title = options[:title] || I18n.t("admin.#{attribute_name}", default: object.class.han(attribute_name))
|
26
|
-
return template.input_set(title) { attach_file_field(attribute_name, options) }
|
27
36
|
when :map
|
28
37
|
title = options[:title] || I18n.t("admin.#{attribute_name}", default: object.class.han(attribute_name))
|
29
38
|
prefix = options[:prefix] || object.class.model_name.singular
|
30
39
|
data_fields = [:lat, :lon, :zoom].map { |attr| hidden_field(attr) }.join.html_safe
|
31
40
|
return template.input_set(title) { data_fields + geo_input(prefix, options[:js_options]) }
|
32
41
|
when :token
|
33
|
-
options[:label]
|
42
|
+
options[:label] = object.class.han(attribute_name.to_s.sub(/^token_|_id$/, '')) unless options.key?(:label)
|
34
43
|
when :association, :tree_select
|
35
44
|
unless options[:reflection]
|
36
|
-
if options[:as] == :tree_select
|
37
|
-
options[:collection] ||= begin
|
38
|
-
reflection = object.class.reflect_on_association(attribute_name)
|
39
|
-
records = reflection.klass.all(reflection.options.slice(:conditions, :order))
|
40
|
-
reflection.klass.nested_opts_with_parent(records, object)
|
41
|
-
end
|
42
|
-
end
|
45
|
+
options[:collection] ||= fetch_nested_options(attribute_name) if options[:as] == :tree_select
|
43
46
|
return association(attribute_name, options.merge(as: :select))
|
44
47
|
end
|
45
48
|
when :checkbox_tree
|
@@ -52,9 +55,13 @@ module AbAdmin
|
|
52
55
|
super(attribute_name, options, &block)
|
53
56
|
end
|
54
57
|
|
58
|
+
def render_dsl_node(node, options={})
|
59
|
+
input node.name, node.options.merge(options), &node.block
|
60
|
+
end
|
61
|
+
|
55
62
|
def link_to_add_assoc(assoc, options={})
|
56
63
|
model = @object.class.reflect_on_association(assoc).klass
|
57
|
-
title = [@template.icon('plus', true), I18n.t('admin.add'), model.model_name.human].join(' ').html_safe
|
64
|
+
title = [@template.icon('plus', true), I18n.t('admin.add'), options[:title] || model.model_name.human].join(' ').html_safe
|
58
65
|
link_to_add title, assoc, class: "btn btn-primary #{options[:class]}"
|
59
66
|
end
|
60
67
|
|
@@ -93,84 +100,15 @@ module AbAdmin
|
|
93
100
|
HTML
|
94
101
|
end
|
95
102
|
|
96
|
-
|
97
|
-
value = options.delete(:value) if options.key?(:value)
|
98
|
-
value ||= object.fileupload_asset(attribute_name)
|
99
|
-
asset_klass = object.reflections[attribute_name].try(:klass)
|
100
|
-
|
101
|
-
element_guid = object.fileupload_guid
|
102
|
-
element_id = template.dom_id(object, [attribute_name, element_guid].join('_'))
|
103
|
-
max_size = options[:file_max_size] || asset_klass.try(:max_size)
|
104
|
-
script_options = (options.delete(:script) || {}).stringify_keys
|
105
|
-
|
106
|
-
params = {
|
107
|
-
method: attribute_name,
|
108
|
-
assetable_id: object.new_record? ? nil : object.id,
|
109
|
-
assetable_type: object.class.name,
|
110
|
-
guid: element_guid
|
111
|
-
}.merge(script_options.delete(:params) || {})
|
112
|
-
|
113
|
-
script_options['action'] ||= '/sunrise/fileupload?' + Rack::Utils.build_query(params)
|
114
|
-
if !script_options['allowedExtensions'] && asset_klass
|
115
|
-
script_options['allowedExtensions'] = asset_klass.ext_list
|
116
|
-
end
|
117
|
-
if options[:template_id]
|
118
|
-
script_options['template_id'] = options[:template_id]
|
119
|
-
end
|
120
|
-
if options[:file]
|
121
|
-
script_options['allowedExtensions'] ||= %w(pdf doc docx xls xlsx ppt pptx zip rar csv jpg jpeg gif png)
|
122
|
-
script_options['template_id'] = '#fileupload_ftmpl'
|
123
|
-
options[:asset_template] = 'file'
|
124
|
-
elsif options[:video]
|
125
|
-
script_options['allowedExtensions'] ||= %w(mp4 flv)
|
126
|
-
script_options['template_id'] = '#fileupload_vtmpl'
|
127
|
-
options[:asset_template] = 'video'
|
128
|
-
end
|
129
|
-
script_options['allowedExtensions'] ||= %w(jpg jpeg png gif)
|
130
|
-
script_options['multiple'] ||= object.fileupload_multiple?(attribute_name)
|
131
|
-
script_options['element'] ||= element_id
|
132
|
-
script_options['sizeLimit'] = max_size.megabytes.to_i
|
133
|
-
|
134
|
-
locals = {
|
135
|
-
element_id: element_id,
|
136
|
-
error: error(attribute_name),
|
137
|
-
file_title: (options[:file_title] || script_options['allowedExtensions'].join(', ')),
|
138
|
-
file_max_size: max_size,
|
139
|
-
assets: [value].flatten.delete_if { |v| v.nil? || v.new_record? },
|
140
|
-
button_title: options[:button_title] || I18n.t("admin.fileupload.button#{'s' if script_options['multiple']}"),
|
141
|
-
asset_template: (options[:asset_template] || 'asset'),
|
142
|
-
container_data: {
|
143
|
-
klass: params[:assetable_type],
|
144
|
-
asset: asset_klass.to_s,
|
145
|
-
assoc: params[:method],
|
146
|
-
multiple: script_options['multiple'],
|
147
|
-
crop: options[:crop]
|
148
|
-
}
|
149
|
-
}
|
150
|
-
|
151
|
-
locals[:css_class] = ['fileupload', "#{locals[:asset_template]}_render_template"]
|
152
|
-
locals[:css_class] << "#{options[:file] ? 'file' : 'image'}_asset_type"
|
153
|
-
locals[:css_class] << (script_options['multiple'] ? 'many_assets' : 'one_asset')
|
154
|
-
locals[:css_class] << 'error' if locals[:error]
|
155
|
-
|
156
|
-
|
157
|
-
js_opts = [locals[:element_id], template.sort_admin_assets_path(klass: asset_klass), script_options['multiple']].map(&:inspect).join(', ')
|
158
|
-
locals[:js] = <<-JAVASCRIPT
|
159
|
-
var upl = new qq.FileUploaderInput(#{script_options.to_json});
|
160
|
-
upl._setupDragDrop();
|
161
|
-
new AdminAssets(#{js_opts});
|
162
|
-
JAVASCRIPT
|
163
|
-
|
164
|
-
if options[:description]
|
165
|
-
opts = [attribute_name, object.class.name, object.id, object.fileupload_guid].map { |i| i.to_s.inspect }.join(', ')
|
166
|
-
template.concat javascript_tag("$(function(){new AssetDescription(#{opts})})")
|
167
|
-
end
|
103
|
+
protected
|
168
104
|
|
169
|
-
|
105
|
+
def fetch_nested_options(attribute_name)
|
106
|
+
reflection = object.class.reflect_on_association(attribute_name)
|
107
|
+
records = reflection.klass
|
108
|
+
records = records.instance_exec(&reflection.scope) if reflection.scope
|
109
|
+
reflection.klass.nested_opts_with_parent(records.all, object)
|
170
110
|
end
|
171
111
|
|
172
|
-
protected
|
173
|
-
|
174
112
|
def object_plural
|
175
113
|
object_name.to_s.pluralize
|
176
114
|
end
|
@@ -1,11 +1,8 @@
|
|
1
|
+
# -*- encoding : utf-8 -*-
|
1
2
|
module AbAdmin
|
2
3
|
module Views
|
3
4
|
module Helpers
|
4
5
|
|
5
|
-
def pjax?
|
6
|
-
request.headers['X-PJAX']
|
7
|
-
end
|
8
|
-
|
9
6
|
def admin?
|
10
7
|
user_signed_in? && current_user.admin?
|
11
8
|
end
|
@@ -38,17 +35,6 @@ module AbAdmin
|
|
38
35
|
I18n.locale == I18n.default_locale ? '' : "/#{I18n.locale}"
|
39
36
|
end
|
40
37
|
|
41
|
-
def external_link(raw_link, options={}, &block)
|
42
|
-
return unless raw_link.present?
|
43
|
-
options.reverse_merge!(title: raw_link, target: '_blank', rel: 'nofollow')
|
44
|
-
link = raw_link =~ /^http[s]?:\/\// ? raw_link : "http://#{raw_link}"
|
45
|
-
if block_given?
|
46
|
-
link_to link, options, &block
|
47
|
-
else
|
48
|
-
link_to options[:title], link, options
|
49
|
-
end
|
50
|
-
end
|
51
|
-
|
52
38
|
def skype_link(skype, options={})
|
53
39
|
return '' if skype.blank?
|
54
40
|
link_to skype, "skype:#{skype.strip}?chat", options
|
@@ -63,19 +49,6 @@ module AbAdmin
|
|
63
49
|
image_tag image, options
|
64
50
|
end
|
65
51
|
|
66
|
-
def render_title
|
67
|
-
@page_title || I18n.t('page.title')
|
68
|
-
end
|
69
|
-
|
70
|
-
def render_keywords
|
71
|
-
@page_keywords || I18n.t('page.keywords')
|
72
|
-
end
|
73
|
-
|
74
|
-
def render_description
|
75
|
-
@page_description || I18n.t('page.description')
|
76
|
-
end
|
77
|
-
|
78
|
-
# swf_object
|
79
52
|
def swf_object(swf, id, width, height, flash_version, options = {})
|
80
53
|
options.symbolize_keys!
|
81
54
|
|
@@ -0,0 +1,16 @@
|
|
1
|
+
module AbAdmin
|
2
|
+
module Views
|
3
|
+
module Inputs
|
4
|
+
class CaptureBlockInput < ::SimpleForm::Inputs::Base
|
5
|
+
def initialize(*args, &block)
|
6
|
+
super
|
7
|
+
@block = block
|
8
|
+
end
|
9
|
+
|
10
|
+
def input
|
11
|
+
template.capture(@builder, &@block)
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
module AbAdmin
|
2
|
+
module Views
|
3
|
+
module Inputs
|
4
|
+
class DateTimePickerInput < ::SimpleForm::Inputs::Base
|
5
|
+
|
6
|
+
def input
|
7
|
+
input_html_options[:value] ||= formated_value
|
8
|
+
input_html_classes << input_type
|
9
|
+
@builder.text_field(attribute_name, input_html_options)
|
10
|
+
end
|
11
|
+
|
12
|
+
private
|
13
|
+
|
14
|
+
def formated_value
|
15
|
+
object.send(attribute_name).try(:strftime, value_format)
|
16
|
+
end
|
17
|
+
|
18
|
+
def value_format
|
19
|
+
case input_type
|
20
|
+
when :date_picker
|
21
|
+
'%d.%m.%Y'
|
22
|
+
when :datetime_picker
|
23
|
+
'%d.%m.%Y %H:%M'
|
24
|
+
when :time_picker
|
25
|
+
'%H:%M'
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
def has_required?
|
30
|
+
false
|
31
|
+
end
|
32
|
+
|
33
|
+
def label_target
|
34
|
+
case input_type
|
35
|
+
when :date, :datetime
|
36
|
+
"#{attribute_name}_1i"
|
37
|
+
when :time
|
38
|
+
"#{attribute_name}_4i"
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
@@ -5,7 +5,8 @@ module AbAdmin
|
|
5
5
|
|
6
6
|
def input
|
7
7
|
attr = options.delete(:assoc) || attribute_name.to_s.sub(/^token_|_id$/, '')
|
8
|
-
|
8
|
+
token_data = object.token_data(attr.to_sym, options.extract!(:geo_order, :c, :sortable))
|
9
|
+
input_html_options.reverse_deep_merge!(token_data)
|
9
10
|
super
|
10
11
|
end
|
11
12
|
|
@@ -0,0 +1,101 @@
|
|
1
|
+
module AbAdmin
|
2
|
+
module Views
|
3
|
+
module Inputs
|
4
|
+
class UploaderInput < ::SimpleForm::Inputs::Base
|
5
|
+
disable :label
|
6
|
+
|
7
|
+
def initialize(*args, &block)
|
8
|
+
super
|
9
|
+
@assoc = object.class.reflect_on_association(attribute_name)
|
10
|
+
defaults = {
|
11
|
+
file_type: 'image',
|
12
|
+
container_id: "#{attribute_name}_#{object.fileupload_guid}",
|
13
|
+
multiple: @assoc.collection?,
|
14
|
+
extensions: @assoc.klass.ext_list,
|
15
|
+
max_size: @assoc.klass.try(:max_size),
|
16
|
+
error: @builder.error(attribute_name)
|
17
|
+
}
|
18
|
+
@options.reverse_merge!(defaults)
|
19
|
+
@options[:sortable] = @options[:multiple] unless @options.has_key?(:sortable)
|
20
|
+
@options[:asset_template] ||= @options[:file_type]
|
21
|
+
@options[:container_class] = container_class
|
22
|
+
end
|
23
|
+
|
24
|
+
def input
|
25
|
+
title = options[:title] || object.class.han(attribute_name)
|
26
|
+
template.capture do
|
27
|
+
if @options[:unwrapped]
|
28
|
+
render_input
|
29
|
+
else
|
30
|
+
template.input_set(title) { render_input }
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
def render_input
|
36
|
+
locals = {
|
37
|
+
options: @options,
|
38
|
+
js_options: js_options,
|
39
|
+
assets: uploader_values,
|
40
|
+
asset_template: "#{theme_path}/#{@options[:asset_template]}"
|
41
|
+
}
|
42
|
+
template.render(partial: "#{theme_path}/container", locals: locals)
|
43
|
+
end
|
44
|
+
|
45
|
+
def container_class
|
46
|
+
classes = Array(@options[:container_class])
|
47
|
+
classes << (@options[:multiple] ? 'fileupload-multiple' : 'fileupload-single')
|
48
|
+
classes << "fileupload-klass-#{@assoc.klass.name}"
|
49
|
+
classes << "fileupload-record-#{object.fileupload_guid}"
|
50
|
+
classes << "fileupload-theme-#{@options[:theme]}" if @options[:theme]
|
51
|
+
classes << "fileupload-file_type-#{@options[:file_type]}"
|
52
|
+
classes << "fileupload-asset_template-#{@options[:asset_template]}"
|
53
|
+
classes << 'fileupload-sortable' if @options[:sortable]
|
54
|
+
classes << 'error' if @options[:error]
|
55
|
+
classes
|
56
|
+
end
|
57
|
+
|
58
|
+
def theme_path
|
59
|
+
[@options[:views_path] || 'admin/fileupload', @options[:theme]].compact.join('/')
|
60
|
+
end
|
61
|
+
|
62
|
+
def uploader_values
|
63
|
+
if options.key?(:value)
|
64
|
+
values = options.delete(:value)
|
65
|
+
else
|
66
|
+
values = object.fileupload_asset(attribute_name)
|
67
|
+
end
|
68
|
+
Array(values).delete_if { |v| v.nil? || v.new_record? }
|
69
|
+
end
|
70
|
+
|
71
|
+
def js_options
|
72
|
+
{
|
73
|
+
container_id: @options[:container_id],
|
74
|
+
file_type: @options[:file_type],
|
75
|
+
asset_template: @options[:asset_template],
|
76
|
+
multiple: @options[:multiple],
|
77
|
+
sort_url: template.sort_admin_assets_path(klass: @assoc.klass.name),
|
78
|
+
extensions: @options[:extensions],
|
79
|
+
klass: @assoc.klass.name,
|
80
|
+
sortable: @options[:sortable],
|
81
|
+
edit_meta: @options[:edit_meta],
|
82
|
+
crop: @options[:crop],
|
83
|
+
fileupload: {
|
84
|
+
url: AbAdmin.fileupload_url,
|
85
|
+
maxNumberOfFiles: @options[:max_files],
|
86
|
+
maxFileSize: @options[:max_size].try(:megabytes),
|
87
|
+
minFileSize: @options[:min_size].try(:megabytes),
|
88
|
+
formData: {
|
89
|
+
assetable_type: object.class.name,
|
90
|
+
assetable_id: object.id,
|
91
|
+
method: attribute_name,
|
92
|
+
guid: object.fileupload_guid
|
93
|
+
}
|
94
|
+
}
|
95
|
+
}
|
96
|
+
end
|
97
|
+
|
98
|
+
end
|
99
|
+
end
|
100
|
+
end
|
101
|
+
end
|
@@ -2,6 +2,8 @@ module AbAdmin
|
|
2
2
|
module Views
|
3
3
|
module ManagerHelpers
|
4
4
|
|
5
|
+
INDEX_VIEW_ICONS = {table: 'list', tree: 'move', grid: 'th'}
|
6
|
+
|
5
7
|
def table_builder
|
6
8
|
manager.table ||= ::AbAdmin::Config::Table.default_for_model(resource_class)
|
7
9
|
end
|
@@ -14,6 +16,10 @@ module AbAdmin
|
|
14
16
|
manager.form ||= ::AbAdmin::Config::Form.default_for_model(resource_class, skip: [:id, :created_at, :updated_at, :lft, :rgt, :depth])
|
15
17
|
end
|
16
18
|
|
19
|
+
def modal_form_builder
|
20
|
+
manager.modal_form ||= ::AbAdmin::Config::ModalForm.default_for_model(resource_class, skip: [:id, :created_at, :updated_at, :lft, :rgt, :depth])
|
21
|
+
end
|
22
|
+
|
17
23
|
def show_builder
|
18
24
|
manager.show ||= ::AbAdmin::Config::Show.default_for_model(resource_class)
|
19
25
|
end
|
@@ -27,6 +33,12 @@ module AbAdmin
|
|
27
33
|
admin_member_action_path(model_name: resource_collection_name, id: record.id, custom_action: custom_action.name)
|
28
34
|
end
|
29
35
|
end
|
36
|
+
|
37
|
+
def index_view_link(index_view)
|
38
|
+
options = {class: "btn #{('active' if current_index_view == index_view)}", title: t("admin.index_view.#{index_view}")}
|
39
|
+
url = url_for(index_view: index_view)
|
40
|
+
link_to icon(INDEX_VIEW_ICONS[index_view.to_sym]), url, options
|
41
|
+
end
|
30
42
|
end
|
31
43
|
end
|
32
44
|
end
|
@@ -6,15 +6,15 @@ module AbAdmin
|
|
6
6
|
:options_for_select, :options_from_collection_for_select, :hidden_field_tag, to: :@template
|
7
7
|
|
8
8
|
def input(attr, options={})
|
9
|
-
|
10
|
-
content_tag :div, class: "clearfix #{
|
11
|
-
send("#{
|
9
|
+
field_type = field_type(attr, options)
|
10
|
+
content_tag :div, class: "clearfix #{field_type} #{options[:wrapper_class]}" do
|
11
|
+
send("#{field_type}_field", attr, options)
|
12
12
|
end
|
13
13
|
end
|
14
14
|
|
15
15
|
def select_field(attr, options={})
|
16
16
|
label(attr, options[:label]) + content_tag(:div, class: 'controls') do
|
17
|
-
param = "#{options[:value_attr] || attr}_eq"
|
17
|
+
param = options[:param] || "#{options[:value_attr] || attr}_eq"
|
18
18
|
|
19
19
|
if options[:collection].is_a?(Proc)
|
20
20
|
collection = options[:collection].call
|
@@ -26,16 +26,25 @@ module AbAdmin
|
|
26
26
|
collection.map!{|r| [AbAdmin.display_name(r), r.id] }
|
27
27
|
end
|
28
28
|
|
29
|
-
options[:
|
30
|
-
if options[:fancy] ||
|
31
|
-
options[:
|
29
|
+
options[:input_html] ||= {}
|
30
|
+
if options[:fancy] || collection.length > 30
|
31
|
+
options[:input_html][:class] = [options[:input_html][:class], 'fancy_select'].join(' ')
|
32
32
|
end
|
33
33
|
|
34
|
-
html_options = options[:
|
34
|
+
html_options = options[:input_html].merge(include_blank: true, id: "q_#{attr}")
|
35
35
|
select_tag("q[#{param}]", options_for_select(collection, params[:q][param]), html_options)
|
36
36
|
end
|
37
37
|
end
|
38
38
|
|
39
|
+
def ac_select_field(attr, options={})
|
40
|
+
klass = options[:klass]
|
41
|
+
options[:param] ||= "#{options[:value_attr] || attr}_eq"
|
42
|
+
pre_select = params.val(:q, options[:param]) ? klass.where(id: params[:q][options[:param]]).map(&:for_input_token) : []
|
43
|
+
options[:input_html] ||= {}
|
44
|
+
options[:input_html].deep_merge! class: 'fancy_select', data: {class: klass.name, pre: pre_select.to_json}
|
45
|
+
string_field attr, options
|
46
|
+
end
|
47
|
+
|
39
48
|
def date_field(attr, options={})
|
40
49
|
label(attr, options[:label]) + content_tag(:div, class: 'controls') do
|
41
50
|
gt_param, lt_param = "#{attr}_gteq", "#{attr}_lteq"
|
@@ -46,7 +55,7 @@ module AbAdmin
|
|
46
55
|
|
47
56
|
def string_field(attr, options={})
|
48
57
|
label(attr, options[:label]) + content_tag(:div, class: 'controls') do
|
49
|
-
param = "#{options[:value_attr] || attr}_cont"
|
58
|
+
param = options[:param] || "#{options[:value_attr] || attr}_cont"
|
50
59
|
options[:input_html] ||= {}
|
51
60
|
options[:input_html][:id] = "q_#{attr}"
|
52
61
|
text_field_tag("q[#{param}]", params[:q][param], options[:input_html])
|
@@ -69,7 +78,7 @@ module AbAdmin
|
|
69
78
|
|
70
79
|
def boolean_field(attr, options={})
|
71
80
|
content_tag(:div, class: 'pull-left') do
|
72
|
-
param = "#{attr}_eq"
|
81
|
+
param = options[:param] || "#{attr}_eq"
|
73
82
|
content_tag(:label, class: 'checkbox inline') do
|
74
83
|
check_box_tag("q[#{param}]", 1, params[:q][param].to_i == 1, class: 'inline', id: "q_#{attr}") + I18n.t('simple_form.yes')
|
75
84
|
end +
|
@@ -79,8 +88,21 @@ module AbAdmin
|
|
79
88
|
end + label(attr, options[:label], class: 'right-label')
|
80
89
|
end
|
81
90
|
|
91
|
+
def presence_field(attr, options={})
|
92
|
+
content_tag(:div, class: 'pull-left') do
|
93
|
+
content_tag(:label, class: 'checkbox inline') do
|
94
|
+
param = "#{attr}_present"
|
95
|
+
check_box_tag("q[#{param}]", 1, params[:q][param].to_i == 1, class: 'inline', id: "q_#{attr}") + I18n.t('simple_form.yes')
|
96
|
+
end +
|
97
|
+
content_tag(:label, class: 'checkbox inline') do
|
98
|
+
param = "#{attr}_null"
|
99
|
+
check_box_tag("q[#{param}]", 1, params[:q][param].to_i == 1, class: 'inline') + I18n.t('simple_form.no')
|
100
|
+
end
|
101
|
+
end + label(attr, options[:label], class: 'right-label')
|
102
|
+
end
|
103
|
+
|
82
104
|
def hidden_field(attr, options={})
|
83
|
-
hidden_field_tag("q[#{attr}_eq]", options
|
105
|
+
hidden_field_tag("q[#{attr}_eq]", options[:value], options)
|
84
106
|
end
|
85
107
|
|
86
108
|
def label(attr, text=nil, options={})
|
@@ -88,14 +110,15 @@ module AbAdmin
|
|
88
110
|
super(attr, text, options)
|
89
111
|
end
|
90
112
|
|
91
|
-
def
|
92
|
-
return options
|
113
|
+
def field_type(attr, options={})
|
114
|
+
return options[:as].to_sym if options[:as]
|
93
115
|
return :string if attr =~ /^translations_/
|
94
116
|
|
95
117
|
input_type = @object.klass.columns_hash[attr.to_s].try(:type)
|
96
118
|
|
97
119
|
if input_type
|
98
120
|
return :select if options[:collection]
|
121
|
+
return :string if input_type == :text
|
99
122
|
elsif @object.klass.translates? && @object.klass.translated?(attr)
|
100
123
|
options[:value_attr] = "translations_#{attr}"
|
101
124
|
return :string
|