
ActiveAdminDatetimepicker
Adds XDSoft's DateTime picker as a date_time_picker input for forms, and date_time_range for filters.

Installation
Add this line to your application's Gemfile:
gem 'active_admin_datetimepicker'
And then execute:
$ bundle
Or install it yourself as:
$ gem install active_admin_datetimepicker
Using assets via Sprockets
Add the following line into app/assets/stylesheets/active_admin.scss:
@import "active_admin_datetimepicker";
Add the following line into app/assets/javascripts/active_admin.js:
Using assets via NPM/Yarn
Execute:
$ npm i @activeadmin-plugins/active_admin_datetimepicker
Or
$ yarn add @activeadmin-plugins/active_admin_datetimepicker
Or add manually to package.json:
"dependencies": {
"@activeadmin-plugins/active_admin_datetimepicker": "latest"
}
and execute:
$ yarn
Add the following line into app/assets/javascripts/active_admin.js:
import '@activeadmin-plugins/active_admin_datetimepicker';
Add the following line into app/assets/stylesheets/active_admin.scss:
@import '@activeadmin-plugins/active_admin_datetimepicker';
Usage
This plugin adds the date_time_picker input and date_time_range filter, which use the XDSoft DateTime Picker.
The date_time_picker input accepts many of the options available to the standard jQueryUI Datepicker. For example:
filter :created_at, as: :date_time_range
form do |f|
f.input :starts_at, as: :date_time_picker, datepicker_options: { min_date: "2013-10-8", max_date: "+3D" }
f.input :ends_at, as: :date_time_picker, datepicker_options: { min_date: 3.days.ago.to_date, max_date: "+1W +5D" }
end
Override behaviour in initializer
ActiveAdminDatetimepicker::Base.default_datetime_picker_options = {
defaultDate: proc { Time.current.strftime("%Y-%m-%d 00:00") }
}
ActiveAdminDatetimepicker::Base.format = "%Y-%m-%d %H:%M:%S"
Change datetime format
If you want to change the format you need to make sure that front-end and back-end formats are identical.
And remember JS and Ruby datetime format have different syntaxes.
Create configuration file config/initializers/init_datetimepicker.rb:
ActiveAdminDatetimepicker::Base.default_datetime_picker_options = {
format: 'd/m/Y H:i',
defaultTime: proc { Time.current.strftime('%H:00') }
}
ActiveAdminDatetimepicker::Base.format = "%d/%m/%Y %H:%M"
See the datetimepicker documentation for more details.
Contributing