214 lines
5.8 KiB
PHP
214 lines
5.8 KiB
PHP
<?php
|
|
namespace ElementorPro\Modules\Forms;
|
|
|
|
use Elementor\Controls_Manager;
|
|
use ElementorPro\Core\Utils;
|
|
use ElementorPro\Modules\Forms\Data\Controller;
|
|
use Elementor\Core\Experiments\Manager;
|
|
use Elementor\Core\Common\Modules\Ajax\Module as Ajax;
|
|
use ElementorPro\Base\Module_Base;
|
|
use ElementorPro\Modules\Forms\Actions;
|
|
use ElementorPro\Modules\Forms\Classes;
|
|
use ElementorPro\Modules\Forms\Controls\Fields_Map;
|
|
use ElementorPro\Modules\Forms\Registrars\Form_Actions_Registrar;
|
|
use ElementorPro\Modules\Forms\Registrars\Form_Fields_Registrar;
|
|
use ElementorPro\Modules\Forms\Submissions\Component as Form_Submissions_Component;
|
|
use ElementorPro\Modules\Forms\Controls\Fields_Repeater;
|
|
use ElementorPro\Plugin;
|
|
|
|
if ( ! defined( 'ABSPATH' ) ) {
|
|
exit; // Exit if accessed directly.
|
|
}
|
|
|
|
class Module extends Module_Base {
|
|
/**
|
|
* @var Form_Actions_Registrar
|
|
*/
|
|
public $actions_registrar;
|
|
|
|
/**
|
|
* @var Form_Fields_Registrar
|
|
*/
|
|
public $fields_registrar;
|
|
|
|
public function get_name() {
|
|
return 'forms';
|
|
}
|
|
|
|
public function get_widgets() {
|
|
return [
|
|
'Form',
|
|
'Login',
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @deprecated 3.1.0
|
|
*/
|
|
public function localize_settings() {
|
|
Plugin::elementor()->modules_manager->get_modules( 'dev-tools' )->deprecation->deprecated_function( __METHOD__, '3.1.0' );
|
|
|
|
return [];
|
|
}
|
|
|
|
public static function find_element_recursive( $elements, $form_id ) {
|
|
foreach ( $elements as $element ) {
|
|
if ( $form_id === $element['id'] ) {
|
|
return $element;
|
|
}
|
|
|
|
if ( ! empty( $element['elements'] ) ) {
|
|
$element = self::find_element_recursive( $element['elements'], $form_id );
|
|
|
|
if ( $element ) {
|
|
return $element;
|
|
}
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
public function register_controls( Controls_Manager $controls_manager ) {
|
|
$controls_manager->register( new Fields_Repeater() );
|
|
$controls_manager->register( new Fields_Map() );
|
|
}
|
|
|
|
/**
|
|
* @param array $data
|
|
*
|
|
* @return array
|
|
* @throws \Exception
|
|
*/
|
|
public function forms_panel_action_data( array $data ) {
|
|
$document = Utils::_unstable_get_document_for_edit( $data['editor_post_id'] );
|
|
|
|
if ( empty( $data['service'] ) ) {
|
|
throw new \Exception( 'Service required.' );
|
|
}
|
|
|
|
/** @var \ElementorPro\Modules\Forms\Classes\Integration_Base $integration */
|
|
$integration = $this->actions_registrar->get( $data['service'] );
|
|
|
|
if ( ! $integration ) {
|
|
throw new \Exception( 'Action not found.' );
|
|
}
|
|
|
|
return $integration->handle_panel_request( $data );
|
|
}
|
|
|
|
/**
|
|
* @deprecated 3.5.0 Use `fields_registrar->register()` instead.
|
|
*/
|
|
public function add_form_field_type( $type, $instance ) {
|
|
Plugin::elementor()->modules_manager->get_modules( 'dev-tools' )->deprecation->deprecated_function(
|
|
__METHOD__,
|
|
'3.5.0',
|
|
'fields_registrar->register()'
|
|
);
|
|
|
|
$this->fields_registrar->register( $instance, $type );
|
|
}
|
|
|
|
/**
|
|
* @deprecated 3.5.0 Use `actions_registrar->register()` instead.
|
|
*/
|
|
public function add_form_action( $id, $instance ) {
|
|
Plugin::elementor()->modules_manager->get_modules( 'dev-tools' )->deprecation->deprecated_function(
|
|
__METHOD__,
|
|
'3.5.0',
|
|
'actions_registrar->register()'
|
|
);
|
|
|
|
$this->actions_registrar->register( $instance, $id );
|
|
}
|
|
|
|
/**
|
|
* @deprecated 3.5.0 Use `actions_registrar->get()` instead.
|
|
*/
|
|
public function get_form_actions( $id = null ) {
|
|
Plugin::elementor()->modules_manager->get_modules( 'dev-tools' )->deprecation->deprecated_function(
|
|
__METHOD__,
|
|
'3.5.0',
|
|
'actions_registrar->get()'
|
|
);
|
|
|
|
return $this->actions_registrar->get( $id );
|
|
}
|
|
|
|
public function register_ajax_actions( Ajax $ajax ) {
|
|
$ajax->register_ajax_action( 'pro_forms_panel_action_data', [ $this, 'forms_panel_action_data' ] );
|
|
}
|
|
|
|
/**
|
|
* Register submissions
|
|
*/
|
|
private function register_submissions_component() {
|
|
$experiments_manager = Plugin::elementor()->experiments;
|
|
$name = Form_Submissions_Component::NAME;
|
|
|
|
$experiments_manager->add_feature( [
|
|
'name' => $name,
|
|
'title' => esc_html__( 'Form Submissions', 'elementor-pro' ),
|
|
'description' => esc_html__( 'Never lose another submission! Using “Actions After Submit” you can now choose to save all submissions to an internal database.', 'elementor-pro' ),
|
|
'release_status' => Manager::RELEASE_STATUS_STABLE,
|
|
'default' => Manager::STATE_ACTIVE,
|
|
] );
|
|
|
|
if ( ! $experiments_manager->is_feature_active( $name ) ) {
|
|
return;
|
|
}
|
|
|
|
$this->add_component( $name, new Form_Submissions_Component() );
|
|
}
|
|
|
|
/**
|
|
* Module constructor.
|
|
*/
|
|
public function __construct() {
|
|
parent::__construct();
|
|
|
|
add_action( 'elementor/controls/register', [ $this, 'register_controls' ] );
|
|
add_action( 'elementor/ajax/register_actions', [ $this, 'register_ajax_actions' ] );
|
|
|
|
$this->add_component( 'recaptcha', new Classes\Recaptcha_Handler() );
|
|
$this->add_component( 'recaptcha_v3', new Classes\Recaptcha_V3_Handler() );
|
|
$this->add_component( 'honeypot', new Classes\Honeypot_Handler() );
|
|
|
|
$this->register_submissions_component();
|
|
|
|
// Initialize registrars.
|
|
$this->actions_registrar = new Form_Actions_Registrar();
|
|
$this->fields_registrar = new Form_Fields_Registrar();
|
|
|
|
// Add Actions as components, that runs manually in the Ajax_Handler
|
|
|
|
// Activity Log
|
|
if ( function_exists( 'aal_insert_log' ) ) {
|
|
$this->add_component( 'activity_log', new Actions\Activity_Log() );
|
|
}
|
|
|
|
// Contact Form to Database
|
|
if ( function_exists( 'CF7DBPlugin_init' ) ) {
|
|
$this->add_component( 'cf7db', new Actions\CF7DB() );
|
|
}
|
|
|
|
// Ajax Handler
|
|
if ( Classes\Ajax_Handler::is_form_submitted() ) {
|
|
$this->add_component( 'ajax_handler', new Classes\Ajax_Handler() );
|
|
|
|
/**
|
|
* Elementor form submitted.
|
|
*
|
|
* Fires when the form is submitted. This hook allows developers
|
|
* to add functionality after form submission.
|
|
*
|
|
* @since 2.0.0
|
|
*
|
|
* @param Module $this An instance of the form module.
|
|
*/
|
|
do_action( 'elementor_pro/forms/form_submitted', $this );
|
|
}
|
|
}
|
|
}
|