フォームの HTML は、コンポーネントのパーシャル ディレクトリ、テーマのパーシャル ディレクトリに追加するか、任意のページ/レイアウトに直接追加することができます。それは本当に問題ではありません。
パーシャルを含める方法の詳細を読む
{% partial "contact-form.htm" %}
または
{% partial __SELF__ ~ "::contact-form.htm" %} // reference to component's partial
10 月の AJAX フレームワークでは、JavaScript API またはデータ属性を使用する必要があります。例でのやり方は問題ありませんが、onSend ハンドラの前にコンポーネントの名前を追加するのを忘れていました
data-request="SendEmails::onSend"
Where SendEmails
= ページで指定されたコンポーネント名またはエイリアス。フォームがコンポーネントの部分的な使用のみの場合{{ __SELF__ }}::onSend
または JavaScript API を使用する場合は、次のようにします。
$.request('onSend', {
data:{email:email, message:message, name:name},
success: function (data) {
//
},
error:function(e){
//
}
});
次に、リクエストを処理するコンポーネントで関数を作成しますonSend
。
<?php namespace AuthorName\PluginName\Components;
use Cms\Classes\ComponentBase;
use Mail;
use Url;
use Input;
use Request;
use Response;
use ApplicationException;
use Validator;
use ValidationException;
class SendEmails extends ComponentBase
{
public function onSend()
{
if (Request::ajax()) {
try {
$data = post();
// Quick Validation rules for E-mail, Name & Message
if (!array_key_exists('email', $data)) {
$data['email'] = post('email');
}
if (!array_key_exists('norad', $data)) {
$data['message'] = post('message');
}
if (!array_key_exists('name', $data)) {
$data['name'] = post('name');
}
$rules = [
'email' => 'required|email|between:6,255',
'name' => 'required|between:4,255'
//..
];
$validation = Validator::make($data, $rules);
if ($validation->fails()) {
throw new ValidationException($validation);
}
// Check if E-mail Template Exists @ "author.plugin::mail.templatename"
if (View::exists("author.plugin::mail.templatename")) {
Mail::send("author.plugin::mail.templatename", $data, function ($message) {
$message->from('noreply@yourdomain.com', 'Site Name');
$message->to($data['email'], $data['name']);
$message->subject('Subject here..');
});
// Handle Erros
if (count(Mail::failures()) > 0) {
echo "Failed to send Mail "; // Handle Failure
} else {
// Mail sent
echo "Mail Sent!"; // Handle Success
}
}
} catch (Exception $ex) {
throw $ex;
}
}
}
}