Module: ActionMailer::MailHelper

Defined in:
actionmailer/lib/action_mailer/mail_helper.rb

Overview

Provides helper methods for ActionMailer::Base that can be used for easily formatting messages, accessing mailer or message instances, and the attachments list.

Instance Method Summary collapse

Instance Method Details

#attachmentsObject

Access the message attachments list.



31
32
33
# File 'actionmailer/lib/action_mailer/mail_helper.rb', line 31

def attachments
  @_message.attachments
end

#block_format(text) ⇒ Object

Take the text and format it, indented two spaces for each line, and wrapped at 72 columns.



8
9
10
11
12
13
14
15
16
17
18
# File 'actionmailer/lib/action_mailer/mail_helper.rb', line 8

def block_format(text)
  formatted = text.split(/\n\r?\n/).collect { |paragraph|
    format_paragraph(paragraph)
  }.join("\n\n")

  # Make list points stand on their own line
  formatted.gsub!(/[ ]*([*]+) ([^*]*)/) { |s| "  #{$1} #{$2.strip}\n" }
  formatted.gsub!(/[ ]*([#]+) ([^#]*)/) { |s| "  #{$1} #{$2.strip}\n" }

  formatted
end

#format_paragraph(text, len = 72, indent = 2) ⇒ Object

Returns text wrapped at len columns and indented indent spaces.

my_text = 'Here is a sample text with more than 40 characters'

format_paragraph(my_text, 25, 4)
# => "    Here is a sample text with\n    more than 40 characters"


41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
# File 'actionmailer/lib/action_mailer/mail_helper.rb', line 41

def format_paragraph(text, len = 72, indent = 2)
  sentences = [[]]

  text.split.each do |word|
    if sentences.first.present? && (sentences.last + [word]).join(' ').length > len
      sentences << [word]
    else
      sentences.last << word
    end
  end

  indentation = " " * indent
  sentences.map { |sentence|
    "#{indentation}#{sentence.join(' ')}"
  }.join "\n"
end

#mailerObject

Access the mailer instance.



21
22
23
# File 'actionmailer/lib/action_mailer/mail_helper.rb', line 21

def mailer
  @_controller
end

#messageObject

Access the message instance.



26
27
28
# File 'actionmailer/lib/action_mailer/mail_helper.rb', line 26

def message
  @_message
end