Class: Footnotes::Notes::LogNote

Inherits:
AbstractNote show all
Defined in:
lib/rails-footnotes/notes/log_note.rb,
lib/rails-footnotes/notes/log_note/note_logger.rb

Defined Under Namespace

Classes: NoteLogger

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from AbstractNote

close!, #escape, #has_fieldset?, #hash_to_xml_attributes, included?, #initialize, #javascript, #legend, #link, #mount_table, #mount_table_for_hash, #onclick, #prefix?, #row, #stylesheet, title, #to_sym, to_sym, #valid?

Constructor Details

This class inherits a constructor from Footnotes::Notes::AbstractNote

Class Method Details

.start!(controller) ⇒ Object



10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
# File 'lib/rails-footnotes/notes/log_note.rb', line 10

def self.start!(controller)
  self.logs = []
  self.original_logger = Rails.logger
  note_logger = NoteLogger.new(self.logs)
  note_logger.level = self.original_logger.level
  note_logger.formatter =
    if self.original_logger.kind_of?(Logger)
      self.original_logger.formatter
    else
      defined?(ActiveSupport::Logger) ? ActiveSupport::Logger::SimpleFormatter.new : Logger::SimpleFormatter.new
    end

  if ::Rails::VERSION::STRING < "7.1"
    ::Rails.logger.extend(::ActiveSupport::Logger.broadcast(note_logger))
  else
    ::Rails.logger = ::ActiveSupport::BroadcastLogger.new(::Rails.logger, note_logger)
  end
end

Instance Method Details

#contentObject



33
34
35
36
37
38
39
40
41
42
# File 'lib/rails-footnotes/notes/log_note.rb', line 33

def content
  result = '<table>'
    log.compact.each do |l|
      result << "<tr><td>#{l.gsub(/\e\[.+?m/, '')}</td></tr>"
    end
  result << '</table>'
  # Restore formatter
  Rails.logger = self.class.original_logger
  result
end

#logObject



44
45
46
# File 'lib/rails-footnotes/notes/log_note.rb', line 44

def log
  self.class.logs
end

#titleObject



29
30
31
# File 'lib/rails-footnotes/notes/log_note.rb', line 29

def title
  "Log (#{log.count})"
end