diff options
Diffstat (limited to 'help')
| -rw-r--r-- | help/app/controllers/tickets_controller.rb | 67 | ||||
| -rw-r--r-- | help/app/models/ticket.rb | 15 | ||||
| -rw-r--r-- | help/app/models/ticket_comment.rb | 5 | ||||
| -rw-r--r-- | help/app/views/tickets/_comment.html.haml | 34 | ||||
| -rw-r--r-- | help/app/views/tickets/_new_comment.html.haml | 2 | ||||
| -rw-r--r-- | help/app/views/tickets/_ticket.html.haml | 22 | ||||
| -rw-r--r-- | help/app/views/tickets/_ticket_data.html.haml | 14 | ||||
| -rw-r--r-- | help/app/views/tickets/new.html.haml | 3 | 
8 files changed, 96 insertions, 66 deletions
| diff --git a/help/app/controllers/tickets_controller.rb b/help/app/controllers/tickets_controller.rb index d4aa378..b613088 100644 --- a/help/app/controllers/tickets_controller.rb +++ b/help/app/controllers/tickets_controller.rb @@ -6,6 +6,7 @@ class TicketsController < ApplicationController    before_filter :set_strings    before_filter :authorize, :only => [:index] +  before_filter :fetch_ticket, :only => [:show, :update, :destroy] # don't now have an edit method    def new      @ticket = Ticket.new @@ -31,52 +32,44 @@ class TicketsController < ApplicationController  =begin    def edit -    @ticket = Ticket.find(params[:id])      @ticket.comments.build      # build ticket comments?    end  =end    def show -    @ticket = Ticket.find(params[:id])      @comment = TicketComment.new      if !@ticket        redirect_to tickets_path, :alert => "No such ticket"        return      end -    ticket_access_denied? #authorize_ticket_access -    # @ticket.comments.build -    # build ticket comments?    end    def update -    @ticket = Ticket.find(params[:id]) -    if !ticket_access_denied? -      if params[:post] #currently changes to title or is_open status -        @ticket.attributes = params[:post] -        # TODO: do we want to keep the history of title changes? one possibility was adding a comment that said something like 'user changed the title from a to b' - -      else -        params[:ticket][:comments_attributes] = nil if params[:ticket][:comments_attributes].values.first[:body].blank? #unset comments hash if no new comment was typed -        @ticket.attributes = params[:ticket] #this will call comments_attributes= -        @ticket.close if params[:commit] == @reply_close_str #this overrides is_open selection -        # what if there is an update and no new comment? Confirm that there is a new comment to update posted_by: -        @ticket.comments.last.posted_by = (current_user ? current_user.id : nil) if @ticket.comments_changed? #protecting posted_by isn't working, so this should protect it. -      end -      if @ticket.changed? and @ticket.save -        flash[:notice] = 'Ticket was successfully updated.' -        if @ticket.is_open || !logged_in? -          respond_with @ticket -        else #for closed tickets with authenticated users, redirect to index. -          redirect_to tickets_path -        end -      else -        #redirect_to [:show, @ticket] # -        flash[:alert] = 'Ticket has not been changed' -        redirect_to @ticket -        #respond_with(@ticket) # why does this go to edit?? redirect??? +    if params[:post] #currently changes to title or is_open status +      @ticket.attributes = params[:post] +      # TODO: do we want to keep the history of title changes? one possibility was adding a comment that said something like 'user changed the title from a to b' + +    else +      params[:ticket][:comments_attributes] = nil if params[:ticket][:comments_attributes].values.first[:body].blank? #unset comments hash if no new comment was typed +      @ticket.attributes = params[:ticket] #this will call comments_attributes= +      @ticket.close if params[:commit] == @reply_close_str #this overrides is_open selection +      # what if there is an update and no new comment? Confirm that there is a new comment to update posted_by: +      @ticket.comments.last.posted_by = (current_user ? current_user.id : nil) if @ticket.comments_changed? #protecting posted_by isn't working, so this should protect it. +    end +    if @ticket.changed? and @ticket.save +      flash[:notice] = 'Ticket was successfully updated.' +      if @ticket.is_open || !logged_in? +        respond_with @ticket +      else #for closed tickets with authenticated users, redirect to index. +        redirect_to tickets_path        end +    else +      #redirect_to [:show, @ticket] # +      flash[:alert] = 'Ticket has not been changed' +      redirect_to @ticket +      #respond_with(@ticket) # why does this go to edit?? redirect???      end    end @@ -88,7 +81,6 @@ class TicketsController < ApplicationController    def destroy      # should we allow non-admins to delete their own tickets? i don't think necessary. -    @ticket = Ticket.find(params[:id])      @ticket.destroy if admin?      redirect_to tickets_path    end @@ -99,16 +91,19 @@ class TicketsController < ApplicationController      @ticket and (admin? or !@ticket.created_by or (current_user and current_user.id == @ticket.created_by))    end -  def ticket_access_denied? -    access_denied unless ticket_access? -  end - -    def set_strings      @post_reply_str = 'Post reply' #t :post_reply      @reply_close_str = 'Reply and close' #t :reply_and_close    end +  def fetch_ticket +    @ticket = Ticket.find(params[:id]) +    if !@ticket and admin? +      redirect_to tickets_path, :alert => t(:no_such_thing, :thing => 'ticket') +      return +    end +    access_denied unless ticket_access? +  end    # not using now, as we are using comment_attributes= from the Ticket model  =begin    def add_comment diff --git a/help/app/models/ticket.rb b/help/app/models/ticket.rb index a27a9d4..ed1ff9d 100644 --- a/help/app/models/ticket.rb +++ b/help/app/models/ticket.rb @@ -16,7 +16,7 @@ class Ticket < CouchRest::Model::Base    #belongs_to :user #from leap_web_users. doesn't necessarily belong to a user though    property :created_by, String, :protected => true #Integer #nil unless user was authenticated for ticket creation, #THIS should not be changed after being set -  #property :regarding_user, String#Integer # form cannot be submitted if they type in a username w/out corresponding ID. this field can be nil. for authenticated ticket creation by non-admins, should this just automatically be set to be same as created_by?  or maybe we don't use this field unless created_by is nil? +  property :regarding_user, String#Integer # form cannot be submitted if they type in a username w/out corresponding ID. this field can be nil. for authenticated ticket creation by non-admins, should this just automatically be set to be same as created_by?  or maybe we don't use this field unless created_by is nil?    #also, both created_by and regarding_user could be nil---say user forgets username, or has general question    property :title, String    property :email, String #verify @@ -30,7 +30,7 @@ class Ticket < CouchRest::Model::Base    timestamps!    #before_validation :set_created_by, :set_code, :set_email, :on => :create -  before_validation :set_email, :on => :create +  before_validation :set_email, :set_regarding_user, :on => :create    #named_scope :open, :conditions => {:is_open => true} #?? @@ -94,6 +94,10 @@ class Ticket < CouchRest::Model::Base      # in controller set to be current users email if that exists    end +  def set_regarding_user +    self.regarding_user = nil if self.regarding_user == "" +  end +    #not saving with close and reopen, as we will save in update when they are called.    #TODO: not sure if we should bother with these:    def close @@ -132,6 +136,13 @@ class Ticket < CouchRest::Model::Base      end    end +  def created_by_user +    User.find(self.created_by) +  end + +  def regarding_user_actual_user +    User.find_by_login(self.regarding_user) +  end  =begin    def validate      if email_address and not email_address.strip =~ RFC822::EmailAddress diff --git a/help/app/models/ticket_comment.rb b/help/app/models/ticket_comment.rb index 49e5c6c..1df7eec 100644 --- a/help/app/models/ticket_comment.rb +++ b/help/app/models/ticket_comment.rb @@ -7,6 +7,7 @@ class TicketComment    property :posted_at, Time#, :protected => true    #property :posted_verified, TrueClass, :protected => true #should be true if current_user is set when the comment is created    property :body, String +  property :private, TrueClass # private comments are only viewable by admins    # ? timestamps!    validates :body, :presence => true @@ -21,6 +22,10 @@ class TicketComment      !!posted_by    end +  def posted_by_user +    User.find(self.posted_by) +  end +  =begin    #TODO.     #this is resetting all comments associated with the ticket: diff --git a/help/app/views/tickets/_comment.html.haml b/help/app/views/tickets/_comment.html.haml index 1d8ee41..501ceec 100644 --- a/help/app/views/tickets/_comment.html.haml +++ b/help/app/views/tickets/_comment.html.haml @@ -1,16 +1,20 @@  - # style is super ugly but just for now -%tr -  %td -    - if commenter = User.find(comment.posted_by) -      %b -        = 'Posted by' + (commenter.is_admin? ? ' admin' : '') + ':' -      = commenter.login -    - else -      %b -        Unauthenticated post -    .pull-right -      %b -        Posted at: -      = comment.posted_at.to_s(:short) -    %br -    = comment.body +- if admin? or !comment.private # only show comment if user is admin or comment is not private +  %tr +    %td +      - if comment.posted_by_user +        %b +          = 'Posted by' + (comment.posted_by_user.is_admin? ? ' admin' : '') + ':' +        = comment.posted_by_user.login +      - else +        %b +          Unauthenticated post +      - if comment.private +        (Private comment) +      .pull-right +        %b +          Posted at: +        = comment.posted_at.to_s(:short) +      %br +      = comment.body + diff --git a/help/app/views/tickets/_new_comment.html.haml b/help/app/views/tickets/_new_comment.html.haml index 31d134f..96388ea 100644 --- a/help/app/views/tickets/_new_comment.html.haml +++ b/help/app/views/tickets/_new_comment.html.haml @@ -1,2 +1,4 @@  = f.simple_fields_for :comments, @comment do |c|    = c.input :body, :label => 'Comment', :as => :text, :input_html => {:class => "span9", :rows=>4} +  - if admin? +    = c.input :private, :as => :boolean, :label => false, :inline_label => true diff --git a/help/app/views/tickets/_ticket.html.haml b/help/app/views/tickets/_ticket.html.haml index 3edfa8b..7b37652 100644 --- a/help/app/views/tickets/_ticket.html.haml +++ b/help/app/views/tickets/_ticket.html.haml @@ -1,13 +1,17 @@ +- updated_at_text = 'updated: ' + ticket.updated_at.to_s(:long)  %tr    %td      %b        = link_to ticket.title, ticket -    %br -    %small -      created: -      = ticket.created_at.to_s(:short) -      updated: -      = ticket.updated_at.to_s(:short) -    %small.pull-right -      comments by: -      = ticket.commenters  +    - if params[:controller] == 'tickets' +      %br +      %small +        created: +        = ticket.created_at.to_s(:long) +        = updated_at_text +      %small.pull-right +        comments by: +        = ticket.commenters +    - else +      %small +        = updated_at_text
\ No newline at end of file diff --git a/help/app/views/tickets/_ticket_data.html.haml b/help/app/views/tickets/_ticket_data.html.haml index fee080f..d68d3e9 100644 --- a/help/app/views/tickets/_ticket_data.html.haml +++ b/help/app/views/tickets/_ticket_data.html.haml @@ -1,10 +1,20 @@  .spam12    %b      Created by: -  - if User.find(@ticket.created_by) -    = User.find(@ticket.created_by).login +  - if @ticket.created_by_user +    = link_to @ticket.created_by_user.login, edit_user_path(@ticket.created_by_user) #todo: won't want edit path    - else      Unauthenticated ticket creator +  - if @ticket.regarding_user +    %b +      Regarding user: +    - if admin? +      - if @ticket.regarding_user_actual_user +        = link_to @ticket.regarding_user_actual_user.login, edit_user_path(@ticket.regarding_user_actual_user) #todo: won't want edit path +      - else +        = @ticket.regarding_user + ' (no such user)' +    - else # a non-admin is viewing the ticket, so they shouldn't see confirmation of whether the regarding_user exists or not. +      = @ticket.regarding_user    - if @ticket.email      %b        email: diff --git a/help/app/views/tickets/new.html.haml b/help/app/views/tickets/new.html.haml index ee7adb2..1aa689b 100644 --- a/help/app/views/tickets/new.html.haml +++ b/help/app/views/tickets/new.html.haml @@ -3,9 +3,8 @@    = simple_form_for @ticket, :validate => true, :html => {:class => 'form-horizontal'}  do |f|      = f.input :title      = f.input :email if !current_user  #hmm--might authenticated users want to submit an alternate email? +    = f.input :regarding_user      = render :partial => 'new_comment', :locals => {:f => f} -    = # regarding_user if not logged in -    = # email if not logged in      .form-actions        = f.button :submit, :class => 'btn-primary'        = link_to t(:cancel), tickets_path, :class => :btn | 
