SiteSearch.js 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. /**
  2. * --------------------------------------------
  3. * AdminLTE SiteSearch.js
  4. * License MIT
  5. * --------------------------------------------
  6. */
  7. import $ from 'jquery'
  8. /**
  9. * Constants
  10. * ====================================================
  11. */
  12. const NAME = 'SiteSearch'
  13. const DATA_KEY = 'lte.site-search'
  14. const JQUERY_NO_CONFLICT = $.fn[NAME]
  15. const SELECTOR_TOGGLE_BUTTON = '[data-widget="site-search"]'
  16. const SELECTOR_SEARCH_BLOCK = '.site-search-block'
  17. const SELECTOR_SEARCH_BACKDROP = '.site-search-backdrop'
  18. const SELECTOR_SEARCH_INPUT = '.site-search-block .form-control'
  19. const CLASS_NAME_OPEN = 'site-search-open'
  20. const Default = {
  21. transitionSpeed: 300
  22. }
  23. /**
  24. * Class Definition
  25. * ====================================================
  26. */
  27. class SiteSearch {
  28. constructor(_element, _options) {
  29. this.element = _element
  30. this.options = $.extend({}, Default, _options)
  31. }
  32. // Public
  33. open() {
  34. $(SELECTOR_SEARCH_BLOCK).slideDown(this.options.transitionSpeed)
  35. $(SELECTOR_SEARCH_BACKDROP).show(0)
  36. $(SELECTOR_SEARCH_INPUT).focus()
  37. $(SELECTOR_SEARCH_BLOCK).addClass(CLASS_NAME_OPEN)
  38. }
  39. close() {
  40. $(SELECTOR_SEARCH_BLOCK).slideUp(this.options.transitionSpeed)
  41. $(SELECTOR_SEARCH_BACKDROP).hide(0)
  42. $(SELECTOR_SEARCH_BLOCK).removeClass(CLASS_NAME_OPEN)
  43. }
  44. toggle() {
  45. if ($(SELECTOR_SEARCH_BLOCK).hasClass(CLASS_NAME_OPEN)) {
  46. this.close()
  47. } else {
  48. this.open()
  49. }
  50. }
  51. // Static
  52. static _jQueryInterface(options) {
  53. return this.each(function () {
  54. let data = $(this).data(DATA_KEY)
  55. if (!data) {
  56. data = new SiteSearch(this, options)
  57. $(this).data(DATA_KEY, data)
  58. }
  59. if (!/toggle|close/.test(options)) {
  60. throw new Error(`Undefined method ${options}`)
  61. }
  62. data[options]()
  63. })
  64. }
  65. }
  66. /**
  67. * Data API
  68. * ====================================================
  69. */
  70. $(document).on('click', SELECTOR_TOGGLE_BUTTON, event => {
  71. event.preventDefault()
  72. let button = $(event.currentTarget)
  73. if (button.data('widget') !== 'site-search') {
  74. button = button.closest(SELECTOR_TOGGLE_BUTTON)
  75. }
  76. SiteSearch._jQueryInterface.call(button, 'toggle')
  77. })
  78. $(document).on('click', SELECTOR_SEARCH_BACKDROP, event => {
  79. const backdrop = $(event.currentTarget)
  80. SiteSearch._jQueryInterface.call(backdrop, 'close')
  81. })
  82. /**
  83. * jQuery API
  84. * ====================================================
  85. */
  86. $.fn[NAME] = SiteSearch._jQueryInterface
  87. $.fn[NAME].Constructor = SiteSearch
  88. $.fn[NAME].noConflict = function () {
  89. $.fn[NAME] = JQUERY_NO_CONFLICT
  90. return SiteSearch._jQueryInterface
  91. }
  92. export default SiteSearch