diff options
| author | Azul <azul@leap.se> | 2012-12-20 10:57:34 +0100 | 
|---|---|---|
| committer | Azul <azul@leap.se> | 2012-12-20 10:57:34 +0100 | 
| commit | 5d61ba0a80399b9e725881f857fdfa5414e5ef3f (patch) | |
| tree | 041d1938f02b8aa27f68e90f8c71672ec89ce810 /help/app/models/ticket_selection.rb | |
| parent | 69a6c34998328b2168053184e1e487b60e1cc536 (diff) | |
| parent | d6c881294880a934424e4d399786561d5c107167 (diff) | |
Merge remote-tracking branch 'origin/feature/tickets-refactor'
Diffstat (limited to 'help/app/models/ticket_selection.rb')
| -rw-r--r-- | help/app/models/ticket_selection.rb | 58 | 
1 files changed, 58 insertions, 0 deletions
| diff --git a/help/app/models/ticket_selection.rb b/help/app/models/ticket_selection.rb new file mode 100644 index 0000000..cb20f5b --- /dev/null +++ b/help/app/models/ticket_selection.rb @@ -0,0 +1,58 @@ +class TicketSelection + +  def initialize(options = {}) +    @options = options +    @options[:open_status] ||= 'open' +    @options[:sort_order] ||= 'updated_at_desc' + +  end + +  def tickets +    #TODO: can this be more succinct? +    if order +      Ticket.send(finder_method).startkey(startkey).endkey(endkey).send(order) +    else +      Ticket.send(finder_method).startkey(startkey).endkey(endkey) +    end +  end + +  protected + + +  def finder_method +    method = 'by_' +    method += 'includes_post_by_and_' if only_mine? +    method += 'is_open_and_' if @options[:open_status] != 'all' +    method += @options[:sort_order].sub(/_(de|a)sc$/, '') +  end + +  def startkey +    startkeys = [] +    startkeys << @options[:user_id] if only_mine? +    startkeys << (@options[:open_status] == 'open') if @options[:open_status] != 'all' +    startkeys << 0 +    startkeys = startkeys.join if startkeys.length == 1 #want string not array if just one thing in array +    startkeys +  end + +  def endkey +    endtime = Time.now + 2.days #TODO. this obviously isn't ideal +    if self.startkey.is_a?(Array) +      endkeys = self.startkey +      endkeys.pop +      endkeys << endtime +    else +      endtime +    end +  end + +  def order +    'descending' if @options[:sort_order].end_with? 'desc' +  end + + +  def only_mine? +    !@options[:is_admin] or (@options[:admin_status] == 'mine') +  end + +end | 
