Możesz dodać HTML w postaci albo w katalogu partials elementów, częściowy katalogu tematu lub po prostu dodać go do dowolnej strony/układu. To nie ma znaczenia.
Czytaj więcej o tym Partials
{% partial "contact-form.htm" %}
Or
{% partial __SELF__ ~ "::contact-form.htm" %} // reference to component's partial
AJAX ramy październikowy wymaga użycia API JavaScript lub atrybuty danych. To jest w porządku, jak robisz to na przykład, ale zapomniał dodać Nazwa komponentu przed onSend Handler
data-request="SendEmails::onSend"
Gdzie SendEmails
= nazwa składnika lub pseudonim podane na stronie, jeśli formularz jest komponent na częściowe tylko używać {{ __SELF__ }}::onSend
lub z API JavaScriptu, po prostu zrobić:
$.request('onSend', {
data:{email:email, message:message, name:name},
success: function (data) {
//
},
error:function(e){
//
}
});
następnie w obsługi żądania składnika utworzyć funkcję 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('[email protected]', '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;
}
}
}
}
Nie wydaje mi się, że warto utworzyć wtyczkę tylko po to, aby wysłać formularz. To jest bardzo trywialne zadanie, więc możesz użyć sekcji CMS z backendu październikowego, aby dodać kod. –