2017 © Pedro Peláez
 

library twigged-swiftmessage-service-provider

Twig templated Swift_Message builder service provider for the Silex microframework.

image

sinasalek/twigged-swiftmessage-service-provider

Twig templated Swift_Message builder service provider for the Silex microframework.

  • Friday, December 19, 2014
  • by sinasalek
  • Repository
  • 1 Watchers
  • 0 Stars
  • 0 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 1 Versions
  • 0 % Grown

The README.md

TwiggedSwiftMessageServiceProvider

Build Status Latest Stable Version Total Downloads, (*1)

This is a service provider of TwiggedSwiftMessageBuilder for Silex., (*2)

Requirements

  • PHP 5.3+

Getting started

First add this dependency into your composer.json:, (*3)

{
    "require": {
        "qckanemoto/twigged-swiftmessage-service-provider": "1.0.*@dev"
    },
    "minimum-stability": "dev"
}

And enable this service provider in your application. Please notice that you must register both TwigServiceProvider and SwiftmailerServiceProvider on ahead., (*4)

$app->register(new TwigServiceProvider());
$app->register(new SwiftmailerServiceProvider());
$app->register(new \Qck\Silex\Provider\TwiggedSwiftMessageServiceProvider());

Then you can build Swift_Message object via twig template., (*5)

$message = $app['twigged_message']->buildMessage('email.txt.twig');
$message->setTo('hoge@example.com');
$app['mailer']->send($message);

See more detailed documentation here., (*6)

Use submitted form data in Twig template

This service provider provides one additional feature to use submitted form data in Twig template easily. $app['twigged_swiftmessage.form_handler'] allows you to extract data array from Form object., (*7)

Labels and values of each fields can be used as below:, (*8)

  • {{ form.[field-name].label }}
  • {{ form.[field-name].value }}

For example:, (*9)

{# email.txt.twig #}

{% block from %}{{ form.email.value }}{% endblock %}
{% block from_name %}{{ form.name.value }}{% endblock %}
{% block to %}contact@example.com{% endblock %}

{% block subject %}[Contact] {{ form.summary.value }}{% endblock %}

{% block body %}
{% for item in form %}
----------------------------------------------------------------------
{{ item.label }}: {{ item.value }}
{% endfor %}
----------------------------------------------------------------------
{% endblock %}
// in your controller.

$form->handleRequest($request);
if ($form->isValid()) {
    $array = $app['twigged_message.form_handler']->getDataArray($form);
    $message = $app['twigged_message']->buildMessage('email.txt.twig', array('form' => $array));
    $app['mailer']->send($message);
}

Offcourse you also can access to your custom field type as below:, (*10)

  • {{ form.[parent-field].[child-field].label }}
  • {{ form.[parent-field].[child-field].value }}

Enjoy!

See more detailed documentation here., (*11)

The Versions

19/12 2014

dev-master

9999999-dev https://github.com/qckanemoto/TwiggedSwiftMessageServiceProvider

Twig templated Swift_Message builder service provider for the Silex microframework.

  Sources   Download

MIT

The Requires

 

The Development Requires

by Takashi Kanemoto

twig silex swift_message swift_mailer