Elgg  Version master
/root/Elgg/engine/classes/Elgg/FormsService.php

Convenience function for generating a form from a view in a standard location.This function assumes that the body of the form is located at "forms/$action" and sets the action by default to "action/$action". Automatically wraps the forms/$action view with a <form> tag and inserts the anti-csrf security tokens.

@tip This automatically appends elgg-form-action-name to the form's class. It replaces any slashes with dashes (blog/save becomes elgg-form-blog-save)

echo elgg_view_form('login');

This would assume a "login" form body to be at "forms/login" and would set the action of the form to "http://yoursite.com/action/login".

If elgg_view('forms/login') is: <input type="text" name="username" > <input type="password" name="password" >

Then elgg_view_form('login') generates: <form action="http://yoursite.com/action/login" method="post"> ...security tokens... <input type="text" name="username" > <input type="password" name="password" > </form>

Parameters
string$actionThe name of the action. An action name does not include the leading "action/". For example, "login" is an action name.
array$form_vars$vars passed to the "input/form" view
  • 'ajax' bool If true, the form will be submitted with an ajax request
array$body_vars$vars passed to the "forms/<action>" view
Returns
string The complete form
<?php
namespace Elgg;
use Elgg\Traits\Loggable;
class FormsService {
use Loggable;
protected bool $rendering = false;
protected string $footer = '';
public function __construct(
protected ViewsService $views,
protected EventsService $events,
protected ESMService $esm
) {
}
public function render(string $action, array $form_vars = [], array $body_vars = []): string {
'action' => elgg_generate_action_url($action, [], false),
'method' => 'post',
'ajax' => false,
'sticky_enabled' => false,
'sticky_form_name' => $action,
'sticky_ignored_fields' => [],
];
// append elgg-form class to any class options set
'elgg-form-' . preg_replace('/[^a-z0-9]/i', '-', $action)],
);
$form_vars = array_merge($defaults, $form_vars);
if (!isset($form_vars['enctype']) && strtolower($form_vars['method']) == 'post') {
$form_vars['enctype'] = 'multipart/form-data';
}
if (elgg_extract('ajax', $form_vars)) {
$this->esm->import('input/form-ajax');
$form_vars['class'][] = 'elgg-js-ajax-form';
unset($form_vars['ajax']);
}
$form_vars['action_name'] = $action;
$form_vars['ignore_empty_body'] = (bool) elgg_extract('ignore_empty_body', $form_vars, false);
$form_vars['prevent_double_submit'] = (bool) elgg_extract('prevent_double_submit', $form_vars, true);
if (!isset($form_vars['body'])) {
// prepare body vars
$body_vars = (array) $this->events->triggerResults('form:prepare:fields', $action, $form_vars, $body_vars);
$this->rendering = true;
$this->footer = '';
// Render form body
$body = $this->views->renderView("forms/{$action}", $body_vars);
if (!empty($body)) {
// wrap form body
$body = $this->views->renderView('elements/forms/body', [
'body' => $body,
'action_name' => $action,
'body_vars' => $body_vars,
'form_vars' => $form_vars,
]);
// Grab the footer if one was set during form rendering
$body .= $this->views->renderView('elements/forms/footer', [
'footer' => $this->getFooter(),
'action_name' => $action,
'body_vars' => $body_vars,
'form_vars' => $form_vars,
]);
}
$this->rendering = false;
$form_vars['body'] = $body;
}
return elgg_view('input/form', $form_vars);
}
public function setFooter(string $footer = ''): void {
if (!$this->rendering) {
throw new LogicException('Form footer can only be set and retrieved during form rendering, anywhere in elgg_view_form() call stack (e.g. form view, extending views, or view events)');
}
$this->footer = $footer;
}
public function getFooter(): string {
if (!$this->rendering) {
throw new LogicException('Form footer can only be set and retrieved during form rendering, anywhere in elgg_view_form() call stack (e.g. form view, extending views, or view events)');
}
return $this->footer;
}
}
trait Loggable
Enables adding a logger.
Definition: Loggable.php:14
if(!elgg_view_exists("plugins/{$plugin_id}/settings")) $form_vars
foreach($categories as $key=> $category) $body
Definition: categories.php:35
Exception that represents error in the program logic.
Keeps track of ES modules.
Definition: ESMService.php:16
$views
Definition: item.php:17
$body_vars
$footer
Wrap form footer.
Definition: footer.php:11
elgg_extract_class(array $array, array|string $existing=[], string $extract_key='class')
Extract class names from an array, optionally merging into a preexisting set.
Definition: elgglib.php:259
elgg_extract($key, $array, $default=null, bool $strict=true)
Checks for $array[$key] and returns its value if it exists, else returns $default.
Definition: elgglib.php:236
$defaults
Generic entity header upload helper.
Definition: header.php:6
elgg_view(string $view, array $vars=[], string $viewtype='')
Return a parsed view.
Definition: views.php:156
elgg_generate_action_url(string $action, array $query=[], bool $add_csrf_tokens=true)
Generate an action URL.
if(parse_url(elgg_get_site_url(), PHP_URL_PATH) !=='/') if(file_exists(elgg_get_root_path() . 'robots.txt'))
Set robots.txt.
Definition: robots.php:10
$action
Definition: subscribe.php:11