123456789_123456789_123456789_123456789_123456789_

Module: ActionMailer::MailHelper

Relationships & Source Files
Defined in: actionmailer/lib/action_mailer/mail_helper.rb

Overview

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

Instance Method Summary

Instance Method Details

#attachments

Access the message attachments list.

[ GitHub ]

  
# File 'actionmailer/lib/action_mailer/mail_helper.rb', line 53

def attachments
  mailer.attachments
end

#block_format(text)

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

text = <<-TEXT
  This is
  the      paragraph.

  * item1 * item2
TEXT

block_format text
# => "  This is the paragraph.\n\n  * item1\n  * item2\n"
[ GitHub ]

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

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
  output = +""
  splits = formatted.split(/(\*|\#)/)
  while line = splits.shift
    if line.start_with?("*", "#") && splits.first&.start_with?(" ")
      output.chomp!(" ") while output.end_with?(" ")
      output << "  #{line} #{splits.shift.strip}\n"
    else
      output << line
    end
  end

  output
end

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

Returns text wrapped at len columns and indented indent spaces. By default column length len equals 72 characters and indent indent equal two 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"
[ GitHub ]

  
# File 'actionmailer/lib/action_mailer/mail_helper.rb', line 65

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

#mailer

Access the mailer instance.

[ GitHub ]

  
# File 'actionmailer/lib/action_mailer/mail_helper.rb', line 43

def mailer
  @_controller
end

#message

Access the message instance.

[ GitHub ]

  
# File 'actionmailer/lib/action_mailer/mail_helper.rb', line 48

def message
  @_message
end