2011-10-29 16:19:11 +04:00
|
|
|
#-- encoding: UTF-8
|
2011-05-30 00:11:52 +04:00
|
|
|
#-- copyright
|
|
|
|
# ChiliProject is a project management system.
|
2011-05-30 22:52:25 +04:00
|
|
|
#
|
2013-01-07 17:14:21 +04:00
|
|
|
# Copyright (C) 2010-2013 the ChiliProject Team
|
2011-05-30 22:52:25 +04:00
|
|
|
#
|
2011-05-30 00:11:52 +04:00
|
|
|
# This program is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU General Public License
|
|
|
|
# as published by the Free Software Foundation; either version 2
|
|
|
|
# of the License, or (at your option) any later version.
|
2011-05-30 22:52:25 +04:00
|
|
|
#
|
2011-05-30 00:11:52 +04:00
|
|
|
# See doc/COPYRIGHT.rdoc for more details.
|
|
|
|
#++
|
|
|
|
|
2011-05-13 20:55:55 +04:00
|
|
|
module JournalsHelper
|
|
|
|
unloadable
|
|
|
|
include ApplicationHelper
|
|
|
|
include ActionView::Helpers::TagHelper
|
|
|
|
|
|
|
|
def self.included(base)
|
|
|
|
base.class_eval do
|
|
|
|
if respond_to? :before_filter
|
|
|
|
before_filter :find_optional_journal, :only => [:edit]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def render_journal(model, journal, options = {})
|
|
|
|
return "" if journal.initial?
|
2012-01-17 22:25:53 +04:00
|
|
|
|
|
|
|
journal_classes = journal.css_classes
|
2011-07-30 02:04:03 +04:00
|
|
|
journal_content = render_journal_details(journal, :label_updated_time_by, model, options)
|
2012-01-17 22:25:53 +04:00
|
|
|
|
|
|
|
avatar = avatar(journal.user, :size => "40")
|
|
|
|
unless avatar.blank?
|
|
|
|
profile_wrap = content_tag("div", avatar, {:class => "profile-wrap"}, false)
|
|
|
|
journal_content = profile_wrap + journal_content
|
|
|
|
journal_classes << " has-avatar"
|
|
|
|
end
|
|
|
|
|
|
|
|
content_tag("div", journal_content, :id => "change-#{journal.id}", :class => journal_classes)
|
2011-05-13 20:55:55 +04:00
|
|
|
end
|
|
|
|
|
2011-07-30 02:04:03 +04:00
|
|
|
# This renders a journal entry with a header and details
|
|
|
|
def render_journal_details(journal, header_label = :label_updated_time_by, model=nil, options={})
|
2011-05-13 20:55:55 +04:00
|
|
|
header = <<-HTML
|
|
|
|
<h4>
|
2011-03-06 07:01:00 +03:00
|
|
|
<div class="journal-link" style="float:right;">#{link_to "##{journal.anchor}", :anchor => "note-#{journal.anchor}"}</div>
|
2011-05-13 20:55:55 +04:00
|
|
|
#{authoring journal.created_at, journal.user, :label => header_label}
|
2011-03-06 07:01:00 +03:00
|
|
|
#{content_tag('a', '', :name => "note-#{journal.anchor}")}
|
2011-05-13 20:55:55 +04:00
|
|
|
</h4>
|
|
|
|
HTML
|
|
|
|
|
2012-01-17 22:25:53 +04:00
|
|
|
header << render_notes(model, journal, options) unless journal.notes.blank?
|
|
|
|
|
2011-05-13 20:55:55 +04:00
|
|
|
if journal.details.any?
|
2012-01-18 02:43:28 +04:00
|
|
|
details = content_tag "ul", :class => "journal-attributes details" do
|
2011-05-13 20:55:55 +04:00
|
|
|
journal.details.collect do |detail|
|
|
|
|
if d = journal.render_detail(detail)
|
|
|
|
content_tag("li", d)
|
|
|
|
end
|
2011-07-22 22:52:55 +04:00
|
|
|
end.compact.join(' ')
|
2011-05-13 20:55:55 +04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-01-17 22:25:53 +04:00
|
|
|
content_tag "div", "#{header}#{details}", :class => "journal-details"
|
2011-05-13 20:55:55 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
def render_notes(model, journal, options={})
|
|
|
|
controller = model.class.name.downcase.pluralize
|
|
|
|
action = 'edit'
|
|
|
|
reply_links = authorize_for(controller, action)
|
|
|
|
|
|
|
|
if User.current.logged?
|
|
|
|
editable = User.current.allowed_to?(options[:edit_permission], journal.project) if options[:edit_permission]
|
|
|
|
if journal.user == User.current && options[:edit_own_permission]
|
|
|
|
editable ||= User.current.allowed_to?(options[:edit_own_permission], journal.project)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
unless journal.notes.blank?
|
2011-05-14 02:19:53 +04:00
|
|
|
links = [].tap do |l|
|
2011-05-13 20:55:55 +04:00
|
|
|
if reply_links
|
|
|
|
l << link_to_remote(image_tag('comment.png'), :title => l(:button_quote),
|
|
|
|
:url => {:controller => controller, :action => action, :id => model, :journal_id => journal})
|
|
|
|
end
|
|
|
|
if editable
|
|
|
|
l << link_to_in_place_notes_editor(image_tag('edit.png'), "journal-#{journal.id}-notes",
|
|
|
|
{ :controller => 'journals', :action => 'edit', :id => journal },
|
|
|
|
:title => l(:button_edit))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
content = ''
|
|
|
|
content << content_tag('div', links.join(' '), :class => 'contextual') unless links.empty?
|
|
|
|
content << textilizable(journal, :notes)
|
|
|
|
|
|
|
|
css_classes = "wiki"
|
|
|
|
css_classes << " editable" if editable
|
|
|
|
|
|
|
|
content_tag('div', content, :id => "journal-#{journal.id}-notes", :class => css_classes)
|
|
|
|
end
|
|
|
|
|
|
|
|
def link_to_in_place_notes_editor(text, field_id, url, options={})
|
|
|
|
onclick = "new Ajax.Request('#{url_for(url)}', {asynchronous:true, evalScripts:true, method:'get'}); return false;"
|
|
|
|
link_to text, '#', options.merge(:onclick => onclick)
|
|
|
|
end
|
|
|
|
|
|
|
|
# This may conveniently be used by controllers to find journals referred to in the current request
|
|
|
|
def find_optional_journal
|
|
|
|
@journal = Journal.find_by_id(params[:journal_id])
|
|
|
|
end
|
|
|
|
|
|
|
|
def render_reply(journal)
|
|
|
|
user = journal.user
|
|
|
|
text = journal.notes
|
|
|
|
|
|
|
|
# Replaces pre blocks with [...]
|
|
|
|
text = text.to_s.strip.gsub(%r{<pre>((.|\s)*?)</pre>}m, '[...]')
|
|
|
|
content = "#{ll(Setting.default_language, :text_user_wrote, user)}\n> "
|
|
|
|
content << text.gsub(/(\r?\n|\r\n?)/, "\n> ") + "\n\n"
|
|
|
|
|
|
|
|
render(:update) do |page|
|
|
|
|
page << "$('notes').value = \"#{escape_javascript content}\";"
|
|
|
|
page.show 'update'
|
|
|
|
page << "Form.Element.focus('notes');"
|
|
|
|
page << "Element.scrollTo('update');"
|
|
|
|
page << "$('notes').scrollTop = $('notes').scrollHeight - $('notes').clientHeight;"
|
|
|
|
end
|
|
|
|
end
|
2011-05-29 23:50:08 +04:00
|
|
|
end
|