Bind typehead to contact too

This commit is contained in:
Martin Lensment 2014-09-09 13:36:28 +03:00
parent 13349a6bc9
commit 1c165cd1e4
7 changed files with 55 additions and 30 deletions

View file

@ -1,20 +1,9 @@
registrarSource = new Bloodhound(
datumTokenizer: (d) ->
Bloodhound.tokenizers.whitespace d.display_key
Autocomplete.bindTypeahead
remote: '/admin/registrars/search'
selector: '.js-registrar-typeahead'
hiddenSelector: '.js-registrar-id'
queryTokenizer: Bloodhound.tokenizers.whitespace
remote: "/admin/registrars/search?q=%QUERY"
)
registrarSource.initialize()
$(".js-registrars-typeahead").typeahead(
highlight: true,
hint: false
,
displayKey: "display_key"
source: registrarSource.ttAdapter()
).on('typeahead:selected', (e, obj) ->
$('input[name="domain[registrar_id]"]').val obj.id
$('.js-registrar-selected').removeClass('hidden')
$('.js-registrar-unselected').addClass('hidden')
)
Autocomplete.bindTypeahead
remote: '/admin/contacts/search'
selector: '.js-contact-typeahead'
hiddenSelector: '.js-contact-id'

View file

@ -5,7 +5,8 @@
#= require nprogress
#= require nprogress-turbolinks
#= require typeahead.bundle.min
#= require_tree .
#= require autocomplete
#= require app
NProgress.configure
showSpinner: false

View file

@ -0,0 +1,29 @@
class @Autocomplete
@bindTypeahead: (obj) ->
$(obj.selector).typeahead(
highlight: true,
hint: false
,
displayKey: "display_key"
source: Autocomplete.constructSourceAdapter(obj.remote)
).on('typeahead:selected', (e, item) ->
$(obj.hiddenSelector).val item.id
ok = $(obj.hiddenSelector).parent('div.has-feedback').find('.js-typeahead-ok')
remove = $(obj.hiddenSelector).parents('div.has-feedback').find('.js-typeahead-remove')
ok.removeClass('hidden')
remove.addClass('hidden')
)
@constructSourceAdapter: (remote) ->
source = new Bloodhound(
datumTokenizer: (d) ->
Bloodhound.tokenizers.whitespace d.display_key
queryTokenizer: Bloodhound.tokenizers.whitespace
remote: "#{remote}?q=%QUERY"
)
source.initialize()
source.ttAdapter()

View file

@ -1,7 +1,5 @@
class Admin::ContactsController < ApplicationController
def search
c = Contact.arel_table
query_string = "%#{params[:query]}%"
render json: Contact.where(c[:code].matches(query_string)).pluck(:code)
render json: Contact.search_by_query(params[:q])
end
end

View file

@ -144,6 +144,11 @@ class Contact < ActiveRecord::Base
res
end
def search_by_query(query)
res = search(code_cont: query).result
res.reduce([]) { |o, v| o << { id: v[:id], display_key: "#{v.name} (#{v.code})" } }
end
end
private

View file

@ -10,7 +10,7 @@ class Registrar < ActiveRecord::Base
class << self
def search_by_query(query)
res = Registrar.search(name_or_reg_no_cont: query).result
res = search(name_or_reg_no_cont: query).result
res.reduce([]) { |o, v| o << { id: v[:id], display_key: "#{v[:name]} (#{v[:reg_no]})" } }
end
end

View file

@ -12,13 +12,16 @@
.col-md-6
.form-group.has-feedback
= f.label :registrar
= f.text_field(:registrar, class: 'form-control js-typeahead js-registrars-typeahead', placeholder: t('shared.registrar_name'), autocomplete: 'off')
%span.glyphicon.glyphicon-remove.form-control-feedback.js-registrar-unselected
%span.glyphicon.glyphicon-ok.form-control-feedback.js-registrar-selected.hidden
= f.hidden_field(:registrar_id)
.form-group
= f.text_field(:registrar, class: 'form-control js-registrar-typeahead', placeholder: t('shared.registrar_name'), autocomplete: 'off')
%span.glyphicon.glyphicon-ok.form-control-feedback.js-typeahead-ok.hidden
%span.glyphicon.glyphicon-remove.form-control-feedback.js-typeahead-remove
= f.hidden_field(:registrar_id, class: 'js-registrar-id')
.form-group.has-feedback
= f.label :owner_contact
= f.text_field(:owner_contact, class: 'form-control js-contacts-typeahead', placeholder: t('shared.contact_code'), autocomplete: 'off')
= f.text_field(:owner_contact, class: 'form-control js-contact-typeahead', placeholder: t('shared.contact_code'), autocomplete: 'off')
%span.glyphicon.glyphicon-ok.form-control-feedback.js-typeahead-ok.hidden
%span.glyphicon.glyphicon-remove.form-control-feedback.js-typeahead-remove
= f.hidden_field(:owner_contact, class: 'js-contact-id')
.row
.col-md-12.text-right
= button_tag(t('shared.save'), class: 'btn btn-primary')