You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
372 lines
11 KiB
PHTML
372 lines
11 KiB
PHTML
8 months ago
|
<?php
|
||
|
|
||
|
// phpcs:ignoreFile Generic.Files.OneObjectStructurePerFile.MultipleFound
|
||
|
|
||
|
namespace WPForms {
|
||
|
/**
|
||
|
* The removed class helps prevent fatal errors for clients
|
||
|
* that use some of the classes we are about to remove.
|
||
|
* Use the class extending instead of class_alias function.
|
||
|
*
|
||
|
* @since 1.8.0
|
||
|
*/
|
||
|
class Removed {
|
||
|
|
||
|
/**
|
||
|
* List of removed classes in the next format:
|
||
|
* Fully-Qualified Class Name => version.
|
||
|
*
|
||
|
* @since 1.8.0
|
||
|
*/
|
||
|
const CLASSES = [
|
||
|
'WPForms\Pro\Admin\Entries\DefaultScreen' => '1.8.2'
|
||
|
];
|
||
|
|
||
|
/**
|
||
|
* Inform clients that the class is removed.
|
||
|
*
|
||
|
* @since 1.8.0
|
||
|
*/
|
||
|
public function __construct() {
|
||
|
|
||
|
self::trigger_error();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Inform clients that the class is removed.
|
||
|
*
|
||
|
* @since 1.8.0
|
||
|
*
|
||
|
* @param string $name Property name.
|
||
|
*/
|
||
|
public function __get( $name ) {
|
||
|
|
||
|
self::trigger_error( $name );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Inform clients that the class is removed.
|
||
|
*
|
||
|
* @since 1.8.0
|
||
|
*
|
||
|
* @param string $name Property name.
|
||
|
* @param mixed $value Property value.
|
||
|
*/
|
||
|
public function __set( $name, $value ) {
|
||
|
|
||
|
self::trigger_error( $name );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Inform clients that the class is removed.
|
||
|
*
|
||
|
* @since 1.8.0
|
||
|
*
|
||
|
* @param string $name Property name.
|
||
|
*/
|
||
|
public function __isset( $name ) {
|
||
|
|
||
|
self::trigger_error( $name );
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* Inform clients that the class is removed.
|
||
|
*
|
||
|
* @since 1.8.0
|
||
|
*
|
||
|
* @param string $name Method name.
|
||
|
* @param array $arguments List of arguments.
|
||
|
*/
|
||
|
public function __call( $name, $arguments ) {
|
||
|
|
||
|
self::trigger_error( $name );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Inform clients that the class is removed.
|
||
|
*
|
||
|
* @since 1.8.0
|
||
|
*
|
||
|
* @param string $name Method name.
|
||
|
* @param array $arguments List of arguments.
|
||
|
*/
|
||
|
public static function __callStatic( $name, $arguments ) {
|
||
|
|
||
|
self::trigger_error( $name );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Inform clients that the class is removed.
|
||
|
*
|
||
|
* @since 1.8.0
|
||
|
*
|
||
|
* @param string $element_name Property or method name.
|
||
|
*/
|
||
|
private static function trigger_error( $element_name = '' ) {
|
||
|
|
||
|
$current_class = static::class;
|
||
|
$removed_element = $current_class;
|
||
|
|
||
|
if ( $element_name ) {
|
||
|
$removed_element .= '::' . $element_name;
|
||
|
}
|
||
|
|
||
|
$version = ! empty( self::CLASSES[ $current_class ] ) ? self::CLASSES[ $current_class ] : WPFORMS_VERSION;
|
||
|
|
||
|
trigger_error(
|
||
|
sprintf(
|
||
|
'%1$s has been removed in %2$s of the WPForms plugin',
|
||
|
esc_html( $removed_element ),
|
||
|
esc_html( $version )
|
||
|
),
|
||
|
E_USER_WARNING
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
namespace WPForms\Forms {
|
||
|
|
||
|
use WPForms\Removed;
|
||
|
|
||
|
class Loader extends Removed {}
|
||
|
}
|
||
|
|
||
|
namespace {
|
||
|
/**
|
||
|
* To be compatible with both WP 4.9 (that can run on PHP 5.2+) and WP 5.3+ (PHP 5.6+)
|
||
|
* we need to rewrite some core WP classes and tweak our own skins to not use PHP 5.6 splat operator (...$args)
|
||
|
* that were introduced in WP 5.3 in \WP_Upgrader_Skin::feedback().
|
||
|
* This alias is a safeguard to those developers who decided to use our internal class WPForms_Install_Silent_Skin,
|
||
|
* which we deleted.
|
||
|
*
|
||
|
* @since 1.5.6.1
|
||
|
*/
|
||
|
class_alias( 'WPForms\Helpers\PluginSilentUpgraderSkin', 'WPForms_Install_Silent_Skin' );
|
||
|
|
||
|
/**
|
||
|
* Legacy `WPForms_Addons` class was refactored and moved to the new `WPForms\Pro\Admin\Pages\Addons` class.
|
||
|
* This alias is a safeguard to those developers who use our internal class WPForms_Addons,
|
||
|
* which we deleted.
|
||
|
*
|
||
|
* @since 1.6.7
|
||
|
*/
|
||
|
class_alias( wpforms()->is_pro() ? 'WPForms\Pro\Admin\Pages\Addons' : 'WPForms\Lite\Admin\Pages\Addons', 'WPForms_Addons' );
|
||
|
|
||
|
/**
|
||
|
* This alias is a safeguard to those developers who decided to use our internal class WPForms_Smart_Tags,
|
||
|
* which we deleted.
|
||
|
*
|
||
|
* @since 1.6.7
|
||
|
*/
|
||
|
class_alias( wpforms()->is_pro() ? 'WPForms\Pro\SmartTags\SmartTags' : 'WPForms\SmartTags\SmartTags', 'WPForms_Smart_Tags' );
|
||
|
|
||
|
/**
|
||
|
* This alias is a safeguard to those developers who decided to use our internal class \WPForms\Providers\Loader,
|
||
|
* which we deleted.
|
||
|
*
|
||
|
* @since 1.7.3
|
||
|
*/
|
||
|
class_alias( '\WPForms\Providers\Providers', '\WPForms\Providers\Loader' );
|
||
|
|
||
|
/**
|
||
|
* Legacy `\WPForms\Admin\Notifications` class was refactored and moved to the new `\WPForms\Admin\Notifications\Notifications` class.
|
||
|
* This alias is a safeguard to those developers who use our internal class \WPForms\Admin\Notifications,
|
||
|
* which we deleted.
|
||
|
*
|
||
|
* @since 1.7.5
|
||
|
*/
|
||
|
class_alias( '\WPForms\Admin\Notifications\Notifications', '\WPForms\Admin\Notifications' );
|
||
|
|
||
|
/**
|
||
|
* Legacy `\WPForms_Field_Payment_Checkbox` class was refactored and moved to the new `\WPForms\Forms\Fields\PaymentCheckbox\Field` class.
|
||
|
* This alias is a safeguard to those developers who use our internal class \WPForms_Field_Payment_Checkbox,
|
||
|
* which we deleted.
|
||
|
*
|
||
|
* @since 1.8.2
|
||
|
*/
|
||
|
class_alias( '\WPForms\Forms\Fields\PaymentCheckbox\Field', '\WPForms_Field_Payment_Checkbox' );
|
||
|
|
||
|
/**
|
||
|
* Legacy `\WPForms_Field_Payment_Multiple` class was refactored and moved to the new `\WPForms\Forms\Fields\PaymentMultiple\Field` class.
|
||
|
* This alias is a safeguard to those developers who use our internal class \WPForms_Field_Payment_Multiple,
|
||
|
* which we deleted.
|
||
|
*
|
||
|
* @since 1.8.2
|
||
|
*/
|
||
|
class_alias( '\WPForms\Forms\Fields\PaymentMultiple\Field', '\WPForms_Field_Payment_Multiple' );
|
||
|
|
||
|
/**
|
||
|
* Legacy `\WPForms_Field_Payment_Single` class was refactored and moved to the new `\WPForms\Forms\Fields\PaymentSingle\Field` class.
|
||
|
* This alias is a safeguard to those developers who use our internal class \WPForms_Field_Payment_Single,
|
||
|
* which we deleted.
|
||
|
*
|
||
|
* @since 1.8.2
|
||
|
*/
|
||
|
class_alias( '\WPForms\Forms\Fields\PaymentSingle\Field', '\WPForms_Field_Payment_Single' );
|
||
|
|
||
|
/**
|
||
|
* Legacy `\WPForms_Field_Payment_Total` class was refactored and moved to the new `\WPForms\Forms\Fields\PaymentTotal\Field` class.
|
||
|
* This alias is a safeguard to those developers who use our internal class \WPForms_Field_Payment_Total,
|
||
|
* which we deleted.
|
||
|
*
|
||
|
* @since 1.8.2
|
||
|
*/
|
||
|
class_alias( '\WPForms\Forms\Fields\PaymentTotal\Field', '\WPForms_Field_Payment_Total' );
|
||
|
|
||
|
/**
|
||
|
* Legacy `\WPForms_Field_Payment_Select` class was refactored and moved to the new `\WPForms\Forms\Fields\PaymentSelect\Field` class.
|
||
|
* This alias is a safeguard to those developers who use our internal class \WPForms_Field_Payment_Select,
|
||
|
* which we deleted.
|
||
|
*
|
||
|
* @since 1.8.2
|
||
|
*/
|
||
|
class_alias( '\WPForms\Forms\Fields\PaymentSelect\Field', '\WPForms_Field_Payment_Select' );
|
||
|
|
||
|
/**
|
||
|
* Legacy `\WPForms\Migrations` class was refactored and moved to the new `\WPForms\Migrations\Migrations` class.
|
||
|
* This alias is a safeguard to those developers who use our internal class \WPForms\Migrations, which we deleted.
|
||
|
*
|
||
|
* @since 1.7.5
|
||
|
*/
|
||
|
class_alias( '\WPForms\Migrations\Migrations', '\WPForms\Migrations' );
|
||
|
|
||
|
if ( wpforms()->is_pro() ) {
|
||
|
/**
|
||
|
* Legacy `\WPForms\Pro\Migrations` class was refactored and moved to the new `\WPForms\Pro\Migrations\Migrations` class.
|
||
|
* This alias is a safeguard to those developers who use our internal class \WPForms\Migrations, which we deleted.
|
||
|
*
|
||
|
* @since 1.7.5
|
||
|
*/
|
||
|
class_alias( '\WPForms\Pro\Migrations\Migrations', '\WPForms\Pro\Migrations' );
|
||
|
|
||
|
/**
|
||
|
* Legacy `\WPForms\Pro\Integrations\TranslationsPress\Translations` class was refactored and moved to the new
|
||
|
* `\WPForms\Pro\Integrations\Translations\Translations` class.
|
||
|
* This alias is a safeguard to those developers who use our internal class \WPForms\Pro\Integrations\TranslationsPress, which we deleted.
|
||
|
*
|
||
|
* @since 1.8.2.2
|
||
|
*/
|
||
|
class_alias( '\WPForms\Pro\Integrations\Translations\Translations', '\WPForms\Pro\Integrations\TranslationsPress\Translations' );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Legacy `\WPForms_Frontend` class was refactored and moved to the new `\WPForms\Frontend\Frontend` class.
|
||
|
* This alias is a safeguard to those developers who use our internal class \WPForms_Frontend, which we deleted.
|
||
|
*
|
||
|
* @since 1.8.1
|
||
|
*/
|
||
|
class_alias( '\WPForms\Frontend\Frontend', '\WPForms_Frontend' );
|
||
|
|
||
|
/**
|
||
|
* This adds backwards compatibility after scoping the stripe lib and using our own prefix `\WPForms\Vendor\Stripe`.
|
||
|
* This alias is a safeguard for the users who update core plugin to 1.8.5 but have older version of stripe pro addon.
|
||
|
* Fire this right before autoloading of legacy classes so that there is no conflict with other stripe libs when aliasing.
|
||
|
*
|
||
|
* @since 1.8.5
|
||
|
*/
|
||
|
spl_autoload_register(
|
||
|
static function ( $class_name ) {
|
||
|
static $stripe_check_done = false;
|
||
|
|
||
|
static $aliases = [
|
||
|
'\WPForms\Vendor\Stripe\Charge' => 'Stripe\Charge',
|
||
|
'\WPForms\Vendor\Stripe\Customer' => 'Stripe\Customer',
|
||
|
'\WPForms\Vendor\Stripe\Subscription' => 'Stripe\Subscription',
|
||
|
'\WPForms\Vendor\Stripe\Invoice' => 'Stripe\Invoice',
|
||
|
'\WPForms\Vendor\Stripe\Exception\CardException' => 'Stripe\Exception\CardException',
|
||
|
'\WPForms\Vendor\Stripe\Source' => 'Stripe\Source',
|
||
|
];
|
||
|
|
||
|
if ( $stripe_check_done ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
// If class not for aliasing, bail.
|
||
|
if ( ! in_array( $class_name, $aliases, true ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$stripe_check_done = true;
|
||
|
|
||
|
// If no Stripe Pro addon bail.
|
||
|
if ( ! defined( 'WPFORMS_STRIPE_VERSION' ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
// Version 3.2.0 has prefixed lib.
|
||
|
// Versions 2.11.0 and below already have the lib bundled, so they don't require alias.
|
||
|
if (
|
||
|
version_compare( WPFORMS_STRIPE_VERSION, '3.2.0', '>=' ) ||
|
||
|
version_compare( WPFORMS_STRIPE_VERSION, '2.11.0', '<=' )
|
||
|
) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
// We only need to alias if we are using the legacy API version.
|
||
|
if ( ! \WPFormsStripe\Helpers::is_legacy_api_version() ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
// If a lib is already loaded by a third party plugin,
|
||
|
// checking the CardException class here as a niche to make sure it is the correct library.
|
||
|
if ( class_exists( '\Stripe\Exception\CardException', false ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
foreach ( $aliases as $prefixed => $alias ) {
|
||
|
class_alias( $prefixed, '\\' . $alias );
|
||
|
}
|
||
|
}
|
||
|
);
|
||
|
|
||
|
/**
|
||
|
* Get notification state, whether it's opened or closed.
|
||
|
*
|
||
|
* @since 1.4.1
|
||
|
* @deprecated 1.4.8
|
||
|
*
|
||
|
* @param int $notification_id Notification ID.
|
||
|
*
|
||
|
* @param int $form_id Form ID.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
function wpforms_builder_notification_get_state( $form_id, $notification_id ) {
|
||
|
|
||
|
_deprecated_function( __FUNCTION__, '1.4.8 of the WPForms addon', 'wpforms_builder_settings_block_get_state()' );
|
||
|
|
||
|
return wpforms_builder_settings_block_get_state( $form_id, $notification_id, 'notification' );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Convert bytes to megabytes (or in some cases KB).
|
||
|
*
|
||
|
* @since 1.0.0
|
||
|
* @deprecated 1.6.2
|
||
|
*
|
||
|
* @param int $bytes Bytes to convert to a readable format.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
function wpforms_size_to_megabytes( $bytes ) {
|
||
|
|
||
|
_deprecated_function( __FUNCTION__, '1.6.2 of the WPForms plugin', 'size_format()' );
|
||
|
|
||
|
return size_format( $bytes );
|
||
|
}
|
||
|
}
|
||
|
|
||
|
namespace WPForms\Pro\Admin\Entries {
|
||
|
|
||
|
/**
|
||
|
* Default Entries screen showed a chart and the form entries stats.
|
||
|
* Replaced with "WPForms\Pro\Admin\Entries\Overview".
|
||
|
*
|
||
|
* @since 1.5.5
|
||
|
* @deprecated 1.8.2
|
||
|
*/
|
||
|
class DefaultScreen extends \WPForms\Removed {}
|
||
|
}
|