Sha256: 0030573b263318117fe94755ea539e0834c1d7dfdff61bfe123042de39929424

Contents?: true

Size: 1.7 KB

Versions: 38

Compression:

Stored size: 1.7 KB

Contents

# Disable dropdown opening when clicking the clear button
# http://stackoverflow.com/questions/29618382/disable-dropdown-opening-on-select2-clear
$(document).on 'select2:unselecting', (event) -> $(event.target).data('state', 'unselected')
$(document).on 'select2:open', (event) ->
  $select = $(event.target)

  if $select.data('state') == 'unselected'
    $select.removeData('state')
    setTimeout ( => $select.select2('close') ), 0


# effective_select custom reinitialization functionality
# This is a custom event intended to be manually triggered when the underlying options change
# You can use this to dynamically disable options (with or without the effective_select hide_disabled: true)
# https://github.com/select2/select2/issues/2830

# To trigger this event,
# $(document).on 'change', "select[name$='[something_id]']", (event) ->
#   ...add/remove/disable this select field's options...
#   $(event.target).select2().trigger('select2:reinitialize')

$(document).on 'select2:reinitialize', (event) ->
  $select = $(event.target)

  # Get the existing options and value
  options = $select.data('select2').options.options['inputJsOptions'] || {}
  value = $select.find('option:selected').val()

  # Clear/Restore the value appropriately
  if value && $select.find("option:enabled[value='#{value}']").length > 0
    $select.val(value)
  else
    $select.val('')

  # Reinitialize select2
  $select.select2('destroy').select2(options)

  # Restore effective_select custom class functionality
  $select.data('select2').$container.addClass(options['containerClass']) if options['containerClass']
  $select.data('select2').$dropdown.addClass(options['dropdownClass']) if options['dropdownClass']

  $select.trigger('change')
  true


Version data entries

38 entries across 38 versions & 1 rubygems

Version Path
effective_bootstrap-0.1.8 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.1.7 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.1.6 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.1.5 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.1.4 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.1.3 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.1.2 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.1.1 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.1.0 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.0.29 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.0.28 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.0.27 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.0.26 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.0.25 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.0.24 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.0.23 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.0.22 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.0.21 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.0.20 app/assets/javascripts/effective_select/overrides.js.coffee
effective_bootstrap-0.0.19 app/assets/javascripts/effective_select/overrides.js.coffee