activeadmin 1.4.3 → 2.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.
- checksums.yaml +4 -4
- data/CHANGELOG.md +92 -11
- data/CONTRIBUTING.md +12 -11
- data/README.md +34 -8
- data/app/assets/javascripts/active_admin/base.es6 +23 -0
- data/app/assets/javascripts/active_admin/ext/jquery-ui.es6 +7 -0
- data/app/assets/javascripts/active_admin/ext/jquery.es6 +9 -0
- data/app/assets/javascripts/active_admin/initializers/datepicker.es6 +16 -0
- data/app/assets/javascripts/active_admin/initializers/filters.es6 +45 -0
- data/app/assets/javascripts/active_admin/initializers/tabs.es6 +6 -0
- data/app/assets/javascripts/active_admin/lib/active_admin.es6 +41 -0
- data/app/assets/javascripts/active_admin/lib/batch_actions.es6 +55 -0
- data/app/assets/javascripts/active_admin/lib/checkbox-toggler.es6 +49 -0
- data/app/assets/javascripts/active_admin/lib/dropdown-menu.es6 +123 -0
- data/app/assets/javascripts/active_admin/lib/has_many.es6 +95 -0
- data/app/assets/javascripts/active_admin/lib/modal_dialog.es6 +61 -0
- data/app/assets/javascripts/active_admin/lib/per_page.es6 +47 -0
- data/app/assets/javascripts/active_admin/lib/table-checkbox-toggler.es6 +36 -0
- data/app/assets/stylesheets/active_admin/_forms.scss +2 -14
- data/app/assets/stylesheets/active_admin/components/_status_tags.scss +0 -5
- data/app/assets/stylesheets/active_admin/components/_tabs.scss +1 -1
- data/app/assets/stylesheets/active_admin/mixins/_gradients.scss +1 -1
- data/app/views/active_admin/devise/confirmations/new.html.erb +1 -1
- data/app/views/active_admin/devise/passwords/edit.html.erb +1 -1
- data/app/views/active_admin/devise/passwords/new.html.erb +1 -1
- data/app/views/active_admin/devise/registrations/new.html.erb +1 -2
- data/app/views/active_admin/devise/shared/_error_messages.html.erb +15 -0
- data/app/views/active_admin/devise/unlocks/new.html.erb +1 -1
- data/app/views/layouts/active_admin_logged_out.html.erb +1 -1
- data/config/locales/bg.yml +0 -1
- data/config/locales/he.yml +0 -1
- data/config/locales/hu.yml +4 -0
- data/config/locales/lt.yml +2 -2
- data/config/locales/uk.yml +2 -0
- data/docs/0-installation.md +2 -2
- data/docs/13-authorization-adapter.md +4 -4
- data/docs/CNAME +1 -1
- data/docs/index.html +2 -2
- data/lib/active_admin/application.rb +8 -14
- data/lib/active_admin/application_settings.rb +3 -0
- data/lib/active_admin/asset_registration.rb +0 -8
- data/lib/active_admin/base_controller/authorization.rb +2 -4
- data/lib/active_admin/base_controller.rb +6 -6
- data/lib/active_admin/batch_actions/controller.rb +1 -1
- data/lib/active_admin/batch_actions/resource_extension.rb +4 -4
- data/lib/active_admin/callbacks.rb +1 -1
- data/lib/active_admin/csv_builder.rb +1 -1
- data/lib/active_admin/dependency.rb +7 -75
- data/lib/active_admin/dsl.rb +1 -8
- data/lib/active_admin/error.rb +1 -1
- data/lib/active_admin/filters/active_filter.rb +3 -1
- data/lib/active_admin/filters/active_sidebar.rb +5 -1
- data/lib/active_admin/filters/forms.rb +2 -2
- data/lib/active_admin/filters/formtastic_addons.rb +1 -1
- data/lib/active_admin/filters/resource_extension.rb +3 -3
- data/lib/active_admin/form_builder.rb +3 -3
- data/lib/active_admin/generators/boilerplate.rb +1 -1
- data/lib/active_admin/helpers/scope_chain.rb +1 -0
- data/lib/active_admin/inputs/datepicker_input.rb +1 -1
- data/lib/active_admin/inputs/filters/base/search_method_select.rb +2 -2
- data/lib/active_admin/menu_item.rb +1 -1
- data/lib/active_admin/namespace.rb +2 -2
- data/lib/active_admin/namespace_settings.rb +7 -4
- data/lib/active_admin/orm/active_record/comments/comment.rb +2 -2
- data/lib/active_admin/orm/active_record/comments/views/active_admin_comments.rb +10 -5
- data/lib/active_admin/orm/active_record/comments.rb +4 -4
- data/lib/active_admin/page_dsl.rb +1 -1
- data/lib/active_admin/pundit_adapter.rb +13 -4
- data/lib/active_admin/resource/action_items.rb +1 -1
- data/lib/active_admin/resource/attributes.rb +7 -4
- data/lib/active_admin/resource/menu.rb +3 -3
- data/lib/active_admin/resource/naming.rb +3 -3
- data/lib/active_admin/resource/routes.rb +9 -4
- data/lib/active_admin/resource/scopes.rb +3 -3
- data/lib/active_admin/resource/sidebars.rb +1 -1
- data/lib/active_admin/resource.rb +2 -2
- data/lib/active_admin/resource_collection.rb +2 -2
- data/lib/active_admin/resource_controller/action_builder.rb +10 -0
- data/lib/active_admin/resource_controller/resource_class_methods.rb +2 -0
- data/lib/active_admin/resource_dsl.rb +5 -3
- data/lib/active_admin/router.rb +1 -1
- data/lib/active_admin/scope.rb +4 -4
- data/lib/active_admin/settings_node.rb +1 -1
- data/lib/active_admin/version.rb +1 -1
- data/lib/active_admin/view_helpers/display_helper.rb +10 -2
- data/lib/active_admin/view_helpers/download_format_links_helper.rb +1 -0
- data/lib/active_admin/view_helpers/method_or_proc_helper.rb +2 -0
- data/lib/active_admin/view_helpers.rb +1 -1
- data/lib/active_admin/views/components/active_admin_form.rb +7 -1
- data/lib/active_admin/views/components/attributes_table.rb +3 -3
- data/lib/active_admin/views/components/paginated_collection.rb +1 -1
- data/lib/active_admin/views/components/sidebar_section.rb +0 -3
- data/lib/active_admin/views/components/status_tag.rb +1 -18
- data/lib/active_admin/views/components/table_for.rb +2 -2
- data/lib/active_admin/views/components/tabs.rb +11 -2
- data/lib/active_admin/views/footer.rb +1 -1
- data/lib/active_admin/views/index_as_table.rb +5 -4
- data/lib/active_admin/views/pages/base.rb +3 -0
- data/lib/active_admin/views.rb +1 -1
- data/lib/active_admin.rb +9 -4
- data/lib/generators/active_admin/assets/assets_generator.rb +2 -2
- data/lib/generators/active_admin/assets/templates/active_admin.js +1 -0
- data/lib/generators/active_admin/install/install_generator.rb +6 -2
- data/lib/generators/active_admin/install/templates/active_admin.rb.erb +20 -1
- data/lib/generators/active_admin/install/templates/dashboard.rb +2 -3
- data/lib/generators/active_admin/install/templates/migrations/create_active_admin_comments.rb.erb +1 -15
- data/lib/generators/active_admin/page/page_generator.rb +1 -1
- data/lib/generators/active_admin/resource/resource_generator.rb +1 -1
- data/lib/ransack_ext.rb +3 -3
- data/vendor/assets/javascripts/jquery-ui/form-reset-mixin.js +80 -0
- data/vendor/assets/javascripts/jquery-ui/form.js +22 -0
- data/vendor/assets/javascripts/jquery-ui/labels.js +65 -0
- data/vendor/assets/javascripts/jquery-ui/widgets/checkboxradio.js +274 -283
- metadata +106 -95
- data/.circleci/config.yml +0 -572
- data/.github/ISSUE_TEMPLATE.md +0 -20
- data/.gitignore +0 -16
- data/.mdlrc +0 -1
- data/.rspec +0 -1
- data/.rspec_parallel +0 -2
- data/.rubocop.yml +0 -99
- data/.simplecov +0 -9
- data/.yardopts +0 -7
- data/Gemfile +0 -30
- data/Gemfile.common +0 -26
- data/Gemfile.lock +0 -433
- data/Rakefile +0 -24
- data/activeadmin.gemspec +0 -32
- data/app/assets/javascripts/active_admin/base.js.coffee +0 -13
- data/app/assets/javascripts/active_admin/ext/jquery-ui.js.coffee +0 -6
- data/app/assets/javascripts/active_admin/ext/jquery.js.coffee +0 -7
- data/app/assets/javascripts/active_admin/initializers/batch_actions.js.coffee +0 -11
- data/app/assets/javascripts/active_admin/initializers/datepicker.js.coffee +0 -14
- data/app/assets/javascripts/active_admin/initializers/filters.js.coffee +0 -26
- data/app/assets/javascripts/active_admin/initializers/tabs.js.coffee +0 -7
- data/app/assets/javascripts/active_admin/lib/batch_actions.js.coffee +0 -42
- data/app/assets/javascripts/active_admin/lib/checkbox-toggler.js.coffee +0 -46
- data/app/assets/javascripts/active_admin/lib/dropdown-menu.js.coffee +0 -104
- data/app/assets/javascripts/active_admin/lib/flash.js.coffee +0 -19
- data/app/assets/javascripts/active_admin/lib/has_many.js.coffee +0 -79
- data/app/assets/javascripts/active_admin/lib/modal_dialog.js.coffee +0 -45
- data/app/assets/javascripts/active_admin/lib/per_page.js.coffee +0 -46
- data/app/assets/javascripts/active_admin/lib/table-checkbox-toggler.js.coffee +0 -22
- data/bin/install_chromedriver.sh +0 -17
- data/config/i18n-tasks.yml +0 -26
- data/config/mdl_style.rb +0 -11
- data/cucumber.yml +0 -7
- data/gemfiles/rails_42.gemfile +0 -10
- data/gemfiles/rails_42.gemfile.lock +0 -339
- data/gemfiles/rails_50.gemfile +0 -10
- data/gemfiles/rails_50.gemfile.lock +0 -353
- data/gemfiles/rails_51.gemfile +0 -10
- data/gemfiles/rails_51.gemfile.lock +0 -353
- data/lib/active_admin/event.rb +0 -24
- data/lib/active_admin/helpers/output_safety_helper.rb +0 -35
- data/lib/bug_report_templates/active_admin_master.rb +0 -111
- data/lib/generators/active_admin/assets/templates/active_admin.js.coffee +0 -1
- data/tasks/application_generator.rb +0 -50
- data/tasks/docs.rake +0 -64
- data/tasks/gemfiles.rake +0 -8
- data/tasks/lint.rake +0 -110
- data/tasks/local.rake +0 -27
- data/tasks/release.rake +0 -6
- data/tasks/test.rake +0 -42
data/lib/active_admin.rb
CHANGED
|
@@ -8,8 +8,8 @@ require 'formtastic'
|
|
|
8
8
|
require 'formtastic_i18n'
|
|
9
9
|
require 'inherited_resources'
|
|
10
10
|
require 'jquery-rails'
|
|
11
|
-
require 'coffee-rails'
|
|
12
11
|
require 'arbre'
|
|
12
|
+
require 'sprockets/es6'
|
|
13
13
|
|
|
14
14
|
require 'active_admin/helpers/i18n'
|
|
15
15
|
|
|
@@ -30,7 +30,6 @@ module ActiveAdmin
|
|
|
30
30
|
autoload :Deprecation, 'active_admin/deprecation'
|
|
31
31
|
autoload :Devise, 'active_admin/devise'
|
|
32
32
|
autoload :DSL, 'active_admin/dsl'
|
|
33
|
-
autoload :Event, 'active_admin/event'
|
|
34
33
|
autoload :FormBuilder, 'active_admin/form_builder'
|
|
35
34
|
autoload :Inputs, 'active_admin/inputs'
|
|
36
35
|
autoload :Localizers, 'active_admin/localizers'
|
|
@@ -90,7 +89,7 @@ module ActiveAdmin
|
|
|
90
89
|
#
|
|
91
90
|
# @param [Block] block A block to call each time (before) AA loads resources
|
|
92
91
|
def before_load(&block)
|
|
93
|
-
ActiveSupport::Notifications.subscribe ActiveAdmin::Application::BeforeLoadEvent, &
|
|
92
|
+
ActiveSupport::Notifications.subscribe ActiveAdmin::Application::BeforeLoadEvent, &wrap_block_for_active_support_notifications(block)
|
|
94
93
|
end
|
|
95
94
|
|
|
96
95
|
# A callback is triggered each time (after) Active Admin loads the configuration files. This
|
|
@@ -108,7 +107,13 @@ module ActiveAdmin
|
|
|
108
107
|
#
|
|
109
108
|
# @param [Block] block A block to call each time (after) AA loads resources
|
|
110
109
|
def after_load(&block)
|
|
111
|
-
ActiveSupport::Notifications.subscribe ActiveAdmin::Application::AfterLoadEvent, &
|
|
110
|
+
ActiveSupport::Notifications.subscribe ActiveAdmin::Application::AfterLoadEvent, &wrap_block_for_active_support_notifications(block)
|
|
111
|
+
end
|
|
112
|
+
|
|
113
|
+
private
|
|
114
|
+
|
|
115
|
+
def wrap_block_for_active_support_notifications block
|
|
116
|
+
proc { |event, *args| block.call *args }
|
|
112
117
|
end
|
|
113
118
|
|
|
114
119
|
end
|
|
@@ -2,10 +2,10 @@ module ActiveAdmin
|
|
|
2
2
|
module Generators
|
|
3
3
|
class AssetsGenerator < Rails::Generators::Base
|
|
4
4
|
|
|
5
|
-
source_root File.expand_path(
|
|
5
|
+
source_root File.expand_path('templates', __dir__)
|
|
6
6
|
|
|
7
7
|
def install_assets
|
|
8
|
-
template 'active_admin.js
|
|
8
|
+
template 'active_admin.js', 'app/assets/javascripts/active_admin.js'
|
|
9
9
|
template "active_admin.scss", "app/assets/stylesheets/active_admin.scss"
|
|
10
10
|
end
|
|
11
11
|
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//= require active_admin/base
|
|
@@ -7,12 +7,14 @@ module ActiveAdmin
|
|
|
7
7
|
argument :name, type: :string, default: "AdminUser"
|
|
8
8
|
|
|
9
9
|
hook_for :users, default: "devise", desc: "Admin user generator to run. Skip with --skip-users"
|
|
10
|
+
class_option :skip_comments, type: :boolean, default: false, desc: "Skip installation of comments"
|
|
10
11
|
|
|
11
|
-
source_root File.expand_path(
|
|
12
|
+
source_root File.expand_path('templates', __dir__)
|
|
12
13
|
|
|
13
14
|
def copy_initializer
|
|
14
15
|
@underscored_user_name = name.underscore.gsub('/', '_')
|
|
15
16
|
@use_authentication_method = options[:users].present?
|
|
17
|
+
@skip_comments = options[:skip_comments]
|
|
16
18
|
template 'active_admin.rb.erb', 'config/initializers/active_admin.rb'
|
|
17
19
|
end
|
|
18
20
|
|
|
@@ -38,7 +40,9 @@ module ActiveAdmin
|
|
|
38
40
|
end
|
|
39
41
|
|
|
40
42
|
def create_migrations
|
|
41
|
-
|
|
43
|
+
unless options[:skip_comments]
|
|
44
|
+
migration_template 'migrations/create_active_admin_comments.rb.erb', 'db/migrate/create_active_admin_comments.rb'
|
|
45
|
+
end
|
|
42
46
|
end
|
|
43
47
|
end
|
|
44
48
|
end
|
|
@@ -69,6 +69,11 @@ ActiveAdmin.setup do |config|
|
|
|
69
69
|
# case when Pundit is unable to find suitable policy.
|
|
70
70
|
# config.pundit_default_policy = "MyDefaultPunditPolicy"
|
|
71
71
|
|
|
72
|
+
# If you wish to maintain a separate set of Pundit policies for admin
|
|
73
|
+
# resources, you may set a namespace here that Pundit will search
|
|
74
|
+
# within when looking for a resource's policy.
|
|
75
|
+
# config.pundit_policy_namespace = :admin
|
|
76
|
+
|
|
72
77
|
# You can customize your CanCan Ability class name here.
|
|
73
78
|
# config.cancan_ability_class = "Ability"
|
|
74
79
|
|
|
@@ -119,7 +124,7 @@ ActiveAdmin.setup do |config|
|
|
|
119
124
|
# This allows your users to comment on any resource registered with Active Admin.
|
|
120
125
|
#
|
|
121
126
|
# You can completely disable comments:
|
|
122
|
-
|
|
127
|
+
<% unless @skip_comments %># <% end %>config.comments = false
|
|
123
128
|
#
|
|
124
129
|
# You can change the name under which comments are registered:
|
|
125
130
|
# config.comments_registration_name = 'AdminComment'
|
|
@@ -147,6 +152,13 @@ ActiveAdmin.setup do |config|
|
|
|
147
152
|
#
|
|
148
153
|
# config.before_action :do_something_awesome
|
|
149
154
|
|
|
155
|
+
# == Attribute Filters
|
|
156
|
+
#
|
|
157
|
+
# You can exclude possibly sensitive model attributes from being displayed,
|
|
158
|
+
# added to forms, or exported by default by ActiveAdmin
|
|
159
|
+
#
|
|
160
|
+
config.filter_attributes = [:encrypted_password, :password, :password_confirmation]
|
|
161
|
+
|
|
150
162
|
# == Localize Date/Time Format
|
|
151
163
|
#
|
|
152
164
|
# Set the localize format to display dates and times.
|
|
@@ -277,6 +289,13 @@ ActiveAdmin.setup do |config|
|
|
|
277
289
|
#
|
|
278
290
|
# config.include_default_association_filters = true
|
|
279
291
|
|
|
292
|
+
# == Head
|
|
293
|
+
#
|
|
294
|
+
# You can add your own content to the site head like analytics. Make sure
|
|
295
|
+
# you only pass content you trust.
|
|
296
|
+
#
|
|
297
|
+
# config.head = ''.html_safe
|
|
298
|
+
|
|
280
299
|
# == Footer
|
|
281
300
|
#
|
|
282
301
|
# By default, the footer shows the current Active Admin version. You can
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
ActiveAdmin.register_page "Dashboard" do
|
|
2
|
+
menu priority: 1, label: proc { I18n.t("active_admin.dashboard") }
|
|
2
3
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
content title: proc{ I18n.t("active_admin.dashboard") } do
|
|
4
|
+
content title: proc { I18n.t("active_admin.dashboard") } do
|
|
6
5
|
div class: "blank_slate_container", id: "dashboard_default_message" do
|
|
7
6
|
span class: "blank_slate" do
|
|
8
7
|
span I18n.t("active_admin.dashboard_welcome.welcome")
|
data/lib/generators/active_admin/install/templates/migrations/create_active_admin_comments.rb.erb
CHANGED
|
@@ -1,27 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
parent_class = ActiveRecord::Migration
|
|
3
|
-
parent_class = parent_class[parent_class.current_version] if Rails::VERSION::MAJOR >= 5
|
|
4
|
-
-%>
|
|
5
|
-
class CreateActiveAdminComments < <%= parent_class.to_s %>
|
|
1
|
+
class CreateActiveAdminComments < ActiveRecord::Migration[<%= ActiveRecord::Migration.current_version.to_s %>]
|
|
6
2
|
def self.up
|
|
7
3
|
create_table :active_admin_comments do |t|
|
|
8
4
|
t.string :namespace
|
|
9
5
|
t.text :body
|
|
10
6
|
t.references :resource, polymorphic: true
|
|
11
7
|
t.references :author, polymorphic: true
|
|
12
|
-
<%- if Rails::VERSION::MAJOR >= 5 -%>
|
|
13
8
|
t.timestamps
|
|
14
|
-
<%- else -%>
|
|
15
|
-
t.timestamps null: false
|
|
16
|
-
<%- end -%>
|
|
17
9
|
end
|
|
18
10
|
add_index :active_admin_comments, [:namespace]
|
|
19
|
-
<%- unless Rails::VERSION::MAJOR >= 5 -%>
|
|
20
|
-
|
|
21
|
-
add_index :active_admin_comments, [:author_type, :author_id]
|
|
22
|
-
add_index :active_admin_comments, [:resource_type, :resource_id]
|
|
23
|
-
<%- end -%>
|
|
24
|
-
|
|
25
11
|
end
|
|
26
12
|
|
|
27
13
|
def self.down
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
module ActiveAdmin
|
|
2
2
|
module Generators
|
|
3
3
|
class PageGenerator < Rails::Generators::NamedBase
|
|
4
|
-
source_root File.expand_path('
|
|
4
|
+
source_root File.expand_path('templates', __dir__)
|
|
5
5
|
|
|
6
6
|
def generate_config_file
|
|
7
7
|
template "page.rb", "app/admin/#{file_path.tr('/', '_')}.rb"
|
|
@@ -8,7 +8,7 @@ module ActiveAdmin
|
|
|
8
8
|
class_option :include_boilerplate, type: :boolean, default: false,
|
|
9
9
|
desc: "Generate boilerplate code for your resource."
|
|
10
10
|
|
|
11
|
-
source_root File.expand_path(
|
|
11
|
+
source_root File.expand_path('templates', __dir__)
|
|
12
12
|
|
|
13
13
|
def generate_config_file
|
|
14
14
|
@boilerplate = ActiveAdmin::Generators::Boilerplate.new(class_name)
|
data/lib/ransack_ext.rb
CHANGED
|
@@ -2,11 +2,11 @@
|
|
|
2
2
|
# identically to the versions given in Ransack.
|
|
3
3
|
#
|
|
4
4
|
Ransack.configure do |config|
|
|
5
|
-
{'contains'=>'cont', 'starts_with'=>'start', 'ends_with'=>'end'}.each do |old, current|
|
|
6
|
-
config.add_predicate old, Ransack::Constants::DERIVED_PREDICATES.detect{ |q, _| q == current }[1]
|
|
5
|
+
{ 'contains'=>'cont', 'starts_with'=>'start', 'ends_with'=>'end' }.each do |old, current|
|
|
6
|
+
config.add_predicate old, Ransack::Constants::DERIVED_PREDICATES.detect { |q, _| q == current }[1]
|
|
7
7
|
end
|
|
8
8
|
|
|
9
|
-
{'equals'=>'eq', 'greater_than'=>'gt', 'less_than'=>'lt'}.each do |old, current|
|
|
9
|
+
{ 'equals'=>'eq', 'greater_than'=>'gt', 'less_than'=>'lt' }.each do |old, current|
|
|
10
10
|
config.add_predicate old, arel_predicate: current
|
|
11
11
|
end
|
|
12
12
|
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
//= require jquery-ui/form
|
|
2
|
+
//= require jquery-ui/version
|
|
3
|
+
|
|
4
|
+
/*!
|
|
5
|
+
* jQuery UI Form Reset Mixin 1.12.1
|
|
6
|
+
* http://jqueryui.com
|
|
7
|
+
*
|
|
8
|
+
* Copyright jQuery Foundation and other contributors
|
|
9
|
+
* Released under the MIT license.
|
|
10
|
+
* http://jquery.org/license
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
//>>label: Form Reset Mixin
|
|
14
|
+
//>>group: Core
|
|
15
|
+
//>>description: Refresh input widgets when their form is reset
|
|
16
|
+
//>>docs: http://api.jqueryui.com/form-reset-mixin/
|
|
17
|
+
|
|
18
|
+
( function( factory ) {
|
|
19
|
+
if ( typeof define === "function" && define.amd ) {
|
|
20
|
+
|
|
21
|
+
// AMD. Register as an anonymous module.
|
|
22
|
+
define( [
|
|
23
|
+
"jquery",
|
|
24
|
+
"./form",
|
|
25
|
+
"./version"
|
|
26
|
+
], factory );
|
|
27
|
+
} else {
|
|
28
|
+
|
|
29
|
+
// Browser globals
|
|
30
|
+
factory( jQuery );
|
|
31
|
+
}
|
|
32
|
+
}( function( $ ) {
|
|
33
|
+
|
|
34
|
+
return $.ui.formResetMixin = {
|
|
35
|
+
_formResetHandler: function() {
|
|
36
|
+
var form = $( this );
|
|
37
|
+
|
|
38
|
+
// Wait for the form reset to actually happen before refreshing
|
|
39
|
+
setTimeout( function() {
|
|
40
|
+
var instances = form.data( "ui-form-reset-instances" );
|
|
41
|
+
$.each( instances, function() {
|
|
42
|
+
this.refresh();
|
|
43
|
+
} );
|
|
44
|
+
} );
|
|
45
|
+
},
|
|
46
|
+
|
|
47
|
+
_bindFormResetHandler: function() {
|
|
48
|
+
this.form = this.element.form();
|
|
49
|
+
if ( !this.form.length ) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
var instances = this.form.data( "ui-form-reset-instances" ) || [];
|
|
54
|
+
if ( !instances.length ) {
|
|
55
|
+
|
|
56
|
+
// We don't use _on() here because we use a single event handler per form
|
|
57
|
+
this.form.on( "reset.ui-form-reset", this._formResetHandler );
|
|
58
|
+
}
|
|
59
|
+
instances.push( this );
|
|
60
|
+
this.form.data( "ui-form-reset-instances", instances );
|
|
61
|
+
},
|
|
62
|
+
|
|
63
|
+
_unbindFormResetHandler: function() {
|
|
64
|
+
if ( !this.form.length ) {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
var instances = this.form.data( "ui-form-reset-instances" );
|
|
69
|
+
instances.splice( $.inArray( this, instances ), 1 );
|
|
70
|
+
if ( instances.length ) {
|
|
71
|
+
this.form.data( "ui-form-reset-instances", instances );
|
|
72
|
+
} else {
|
|
73
|
+
this.form
|
|
74
|
+
.removeData( "ui-form-reset-instances" )
|
|
75
|
+
.off( "reset.ui-form-reset" );
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
} ) );
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
//= require jquery-ui/version
|
|
2
|
+
|
|
3
|
+
( function( factory ) {
|
|
4
|
+
if ( typeof define === "function" && define.amd ) {
|
|
5
|
+
|
|
6
|
+
// AMD. Register as an anonymous module.
|
|
7
|
+
define( [ "jquery", "./version" ], factory );
|
|
8
|
+
} else {
|
|
9
|
+
|
|
10
|
+
// Browser globals
|
|
11
|
+
factory( jQuery );
|
|
12
|
+
}
|
|
13
|
+
} ( function( $ ) {
|
|
14
|
+
|
|
15
|
+
// Support: IE8 Only
|
|
16
|
+
// IE8 does not support the form attribute and when it is supplied. It overwrites the form prop
|
|
17
|
+
// with a string, so we need to find the proper form.
|
|
18
|
+
return $.fn.form = function() {
|
|
19
|
+
return typeof this[ 0 ].form === "string" ? this.closest( "form" ) : $( this[ 0 ].form );
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
} ) );
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
//= require jquery-ui/version
|
|
2
|
+
//= require jquery-ui/escape-selector
|
|
3
|
+
|
|
4
|
+
/*!
|
|
5
|
+
* jQuery UI Labels 1.12.1
|
|
6
|
+
* http://jqueryui.com
|
|
7
|
+
*
|
|
8
|
+
* Copyright jQuery Foundation and other contributors
|
|
9
|
+
* Released under the MIT license.
|
|
10
|
+
* http://jquery.org/license
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
//>>label: labels
|
|
14
|
+
//>>group: Core
|
|
15
|
+
//>>description: Find all the labels associated with a given input
|
|
16
|
+
//>>docs: http://api.jqueryui.com/labels/
|
|
17
|
+
|
|
18
|
+
( function( factory ) {
|
|
19
|
+
if ( typeof define === "function" && define.amd ) {
|
|
20
|
+
|
|
21
|
+
// AMD. Register as an anonymous module.
|
|
22
|
+
define( [ "jquery", "./version", "./escape-selector" ], factory );
|
|
23
|
+
} else {
|
|
24
|
+
|
|
25
|
+
// Browser globals
|
|
26
|
+
factory( jQuery );
|
|
27
|
+
}
|
|
28
|
+
} ( function( $ ) {
|
|
29
|
+
|
|
30
|
+
return $.fn.labels = function() {
|
|
31
|
+
var ancestor, selector, id, labels, ancestors;
|
|
32
|
+
|
|
33
|
+
// Check control.labels first
|
|
34
|
+
if ( this[ 0 ].labels && this[ 0 ].labels.length ) {
|
|
35
|
+
return this.pushStack( this[ 0 ].labels );
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
// Support: IE <= 11, FF <= 37, Android <= 2.3 only
|
|
39
|
+
// Above browsers do not support control.labels. Everything below is to support them
|
|
40
|
+
// as well as document fragments. control.labels does not work on document fragments
|
|
41
|
+
labels = this.eq( 0 ).parents( "label" );
|
|
42
|
+
|
|
43
|
+
// Look for the label based on the id
|
|
44
|
+
id = this.attr( "id" );
|
|
45
|
+
if ( id ) {
|
|
46
|
+
|
|
47
|
+
// We don't search against the document in case the element
|
|
48
|
+
// is disconnected from the DOM
|
|
49
|
+
ancestor = this.eq( 0 ).parents().last();
|
|
50
|
+
|
|
51
|
+
// Get a full set of top level ancestors
|
|
52
|
+
ancestors = ancestor.add( ancestor.length ? ancestor.siblings() : this.siblings() );
|
|
53
|
+
|
|
54
|
+
// Create a selector for the label based on the id
|
|
55
|
+
selector = "label[for='" + $.ui.escapeSelector( id ) + "']";
|
|
56
|
+
|
|
57
|
+
labels = labels.add( ancestors.find( selector ).addBack( selector ) );
|
|
58
|
+
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
// Return whatever we have found for labels
|
|
62
|
+
return this.pushStack( labels );
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
} ) );
|