You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

Extras.md 3.8 KiB

4 years ago
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. # Extras
  2. Guides for making the picker work better with rails, IE, etc
  3. ## Rails 3
  4. by [dhulihan](https://github.com/dhulihan)
  5. You can easily override the default rails form helpers (`date_select` and `datetime_select`) with bootstrap-datetimepicker for a much nicer experience.
  6. ```rb
  7. # Add to config/initializers/form.rb or the end of app/helpers/application_helper.rb
  8. module ActionView
  9. module Helpers
  10. class FormBuilder
  11. def date_select(method, options = {}, html_options = {})
  12. existing_date = @object.send(method)
  13. formatted_date = existing_date.to_date.strftime("%F") if existing_date.present?
  14. @template.content_tag(:div, :class => "input-group") do
  15. text_field(method, :value => formatted_date, :class => "form-control datepicker", :"data-date-format" => "YYYY-MM-DD") +
  16. @template.content_tag(:span, @template.content_tag(:span, "", :class => "glyphicon glyphicon-calendar") ,:class => "input-group-addon")
  17. end
  18. end
  19. def datetime_select(method, options = {}, html_options = {})
  20. existing_time = @object.send(method)
  21. formatted_time = existing_time.to_time.strftime("%F %I:%M %p") if existing_time.present?
  22. @template.content_tag(:div, :class => "input-group") do
  23. text_field(method, :value => formatted_time, :class => "form-control datetimepicker", :"data-date-format" => "YYYY-MM-DD hh:mm A") +
  24. @template.content_tag(:span, @template.content_tag(:span, "", :class => "glyphicon glyphicon-calendar") ,:class => "input-group-addon")
  25. end
  26. end
  27. end
  28. end
  29. end
  30. ```
  31. The time format used here is ActiveRecord-friendly, which means it will be parsed correctly when passed in through `params` to your record.
  32. That's all there is to it! Now all of your forms that use `datetime_select` or `date_select` will be automatically updated:
  33. ```erb
  34. <% form_for @post do |f| %>
  35. <div class="form-group">
  36. <label>Published At</label>
  37. <%= f.datetime_select :published_at %>
  38. </div>
  39. <% end %>
  40. ```
  41. ## IE 7
  42. by [EquilibriumCST](https://github.com/EquilibriumCST)
  43. I succeed to run this widget under IE7.
  44. Here is what I did.
  45. 1. gliphicons are not working under IE7 so add [this css file](https://github.com/coliff/bootstrap-ie7). And this enables the icons.
  46. 2. Z-index problem with IE 7. I added position: relative and `z-index: 10` to the parent container. Otherwise popup is shown under the next elements.
  47. 3. JS events were not working well.
  48. If you open the datetimepicker widget and click on some button or date inside it, widget is automatically closed.
  49. So I added `debug: true` as an option when initializing the widget. Why I did this? I saw on line 1121 from bootsrap-datetimepicker.js the code `'blur': options.debug ? '' : hide`.
  50. And now widget window is not closed on every click inside it, but now you can't close it anyway :)
  51. And closing should be done manually. I've added this document click handler. If you click something outside the widget, now closing works.
  52. ```
  53. $(document).click(function(e){
  54. var target = $(e.target);
  55. if(target.parents('.bootstrap-datetimepicker-widget').length < 1 && !target.hasClass('datetimepickerInput') && !target.hasClass('datepickerIcon') && !target.hasClass('clockpickerIcon')){
  56. if($('.bootstrap-datetimepicker-widget').length > 0){
  57. $('#startDate').data('DateTimePicker').hide();
  58. $('#startTime').data('DateTimePicker').hide();
  59. $('.datetimepickerInput').blur();
  60. }
  61. }
  62. });
  63. ```
  64. But if you have more than one widget on the page like I did, clicking on one widget does'n close the other. Added below lines and now all works fine.
  65. ```
  66. $('#widget1').on("dp.show",function (e) {
  67. $('#widget2).data('DateTimePicker').hide();
  68. });
  69. $('#widget2').on("dp.show",function (e) {
  70. $('#widget1).data('DateTimePicker').hide();
  71. });
  72. ```
  73. I hope this will help to the others who are fighting with the old IE versions :)