Sha256: 4f7f8ae090400e204805e8137de134511b35ff26a2d598b1b574213eb63699c6

Contents?: true

Size: 1.93 KB

Versions: 35

Compression:

Stored size: 1.93 KB

Contents

module ActionMailer
  # Provides helper methods for ActionMailer::Base that can be used for easily
  # formatting messages, accessing mailer or message instances, and the
  # attachments list.
  module MailHelper
    # 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"
    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!(/[ ]*([*]+) ([^*]*)/) { "  #{$1} #{$2.strip}\n" }
      formatted.gsub!(/[ ]*([#]+) ([^#]*)/) { "  #{$1} #{$2.strip}\n" }

      formatted
    end

    # Access the mailer instance.
    def mailer
      @_controller
    end

    # Access the message instance.
    def message
      @_message
    end

    # Access the message attachments list.
    def attachments
      mailer.attachments
    end

    # 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"
    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
  end
end

Version data entries

35 entries across 35 versions & 4 rubygems

Version Path
actionmailer-5.0.7.2 lib/action_mailer/mail_helper.rb
actionmailer-5.0.7.1 lib/action_mailer/mail_helper.rb
actionmailer-5.0.7 lib/action_mailer/mail_helper.rb
actionmailer-5.0.6 lib/action_mailer/mail_helper.rb
actionmailer-5.0.6.rc1 lib/action_mailer/mail_helper.rb
actionmailer-5.0.5 lib/action_mailer/mail_helper.rb
actionmailer-5.0.5.rc2 lib/action_mailer/mail_helper.rb
actionmailer-5.0.5.rc1 lib/action_mailer/mail_helper.rb
actionmailer-5.0.4 lib/action_mailer/mail_helper.rb
actionmailer-5.0.4.rc1 lib/action_mailer/mail_helper.rb
actionmailer-5.0.3 lib/action_mailer/mail_helper.rb
enju_leaf-1.2.1 vendor/bundle/ruby/2.3/gems/actionmailer-5.0.2/lib/action_mailer/mail_helper.rb
actionmailer-5.0.2 lib/action_mailer/mail_helper.rb
actionmailer-5.0.2.rc1 lib/action_mailer/mail_helper.rb
autocompl-0.2.2 test/dummy/vendor/bundle/ruby/2.3.0/gems/actionmailer-5.0.1/lib/action_mailer/mail_helper.rb
autocompl-0.2.1 test/dummy/vendor/bundle/ruby/2.3.0/gems/actionmailer-5.0.1/lib/action_mailer/mail_helper.rb
autocompl-0.2.0 test/dummy/vendor/bundle/ruby/2.3.0/gems/actionmailer-5.0.1/lib/action_mailer/mail_helper.rb
autocompl-0.1.2 test/dummy/vendor/bundle/ruby/2.3.0/gems/actionmailer-5.0.1/lib/action_mailer/mail_helper.rb
autocompl-0.1.1 test/dummy/vendor/bundle/ruby/2.3.0/gems/actionmailer-5.0.1/lib/action_mailer/mail_helper.rb
autocompl-0.1.0 test/dummy/vendor/bundle/ruby/2.3.0/gems/actionmailer-5.0.1/lib/action_mailer/mail_helper.rb