forked from OpenNeo/impress
fix the necklace/collar advanced search bug!
Ooh, this one was nasty, and only one symptom ever got noticed: 1. Pick "Occupies: Collar" in Advanced Search. You get the text query "occupies:necklace". 2. And, if you try to do "occupies:collar" even in text-based search, you *also* get the results from "occupies:necklace" mixed in with the correct results. The trick is that, in Spanish, zone 24 (necklace) is named "collar", as is zone 27 (collar). Not sure what to do for Spanish, but this issue also leaked into English: we really don't want English to return results for Spanish-named zones. This is a tricky problem, though, because it'd be nice for es users to be able to type "occupies:hat". I think we'll have to do the quick fix for now, though, and just only interpret the query in the current locale.
This commit is contained in:
parent
973bbbcb0a
commit
c8b9833dee
1 changed files with 3 additions and 1 deletions
|
@ -11,7 +11,9 @@ class Zone < ActiveRecord::Base
|
||||||
scope :includes_translations, lambda { includes(:translations) }
|
scope :includes_translations, lambda { includes(:translations) }
|
||||||
scope :with_plain_label, lambda { |label|
|
scope :with_plain_label, lambda { |label|
|
||||||
t = Zone::Translation.arel_table
|
t = Zone::Translation.arel_table
|
||||||
includes(:translations).where(t[:plain_label].eq(Zone.plainify_label(label)))
|
includes(:translations)
|
||||||
|
.where(t[:plain_label].eq(Zone.plainify_label(label)))
|
||||||
|
.where(t[:locale].eq(I18n.locale))
|
||||||
}
|
}
|
||||||
scope :for_items, lambda { where(arel_table[:type_id].gt(1)) }
|
scope :for_items, lambda { where(arel_table[:type_id].gt(1)) }
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue