File: /home/globfdxw/www/wp-content/plugins/give/src/FormBuilder/Routes/RegisterFormBuilderPageRoute.php
<?php
namespace Give\FormBuilder\Routes;
use Give\Campaigns\Models\Campaign;
use Give\Framework\Permissions\Facades\UserPermissions;
use Give\FormBuilder\FormBuilderRouteBuilder;
use Give\FormBuilder\ViewModels\FormBuilderViewModel;
use Give\Framework\Views\View;
use Give\Helpers\Hooks;
use Give\Helpers\Language;
use Give\Log\Log;
use function wp_enqueue_style;
/**
* Add form builder page route and scripts
*/
class RegisterFormBuilderPageRoute
{
/**
* Use add_submenu_page to register page within WP admin
*
* @since 4.14.0 update permission capability to use facade
* @since 4.3.2 update capability to edit_give_forms
* @since 4.0.0 set parent slug to empty string
* @since 3.0.0
*
* @return void
*/
public function __invoke()
{
add_submenu_page(
'', // do not display in menu, just register page
'Visual Donation Form Builder', // ignored
'Add Form', // ignored
UserPermissions::donationForms()->editCap(),
FormBuilderRouteBuilder::SLUG,
[$this, 'renderPage'],
1
);
add_action("admin_print_styles", function () {
if (FormBuilderRouteBuilder::isRoute()) {
wp_enqueue_style('givewp-design-system-foundation');
$this->loadGutenbergScripts();
wp_enqueue_style(
'@givewp/form-builder/style-app',
GIVE_PLUGIN_URL . 'build/formBuilderApp.css'
);
wp_enqueue_style(
'givewp-form-builder-admin-styles',
GIVE_PLUGIN_URL . 'src/FormBuilder/resources/css/admin-form-builder.css'
);
}
});
}
/**
* Render page with scripts
*
* @since 3.22.0 Add locale support
* @since 3.1.0 set translations for scripts
* @since 3.0.0
*
* @return void
*/
public function renderPage()
{
$formBuilderViewModel = new FormBuilderViewModel();
$donationFormId = abs($_GET['donationFormID']);
// validate form exists before proceeding
// TODO: improve on this validation
if (!get_post($donationFormId)) {
wp_die(__('Donation form does not exist.', 'give'));
}
$locale = give_clean($_GET['locale']) ?? '';
Language::switchToLocale($locale);
wp_enqueue_style(
'@givewp/form-builder/registrars',
GIVE_PLUGIN_URL . 'build/formBuilderRegistrars.css'
);
$registrarsScriptHandle = '@givewp/form-builder/registrars';
wp_enqueue_script(
$registrarsScriptHandle,
$formBuilderViewModel->jsPathToRegistrars(),
$this->getRegisteredFormBuilderJsDependencies(
$formBuilderViewModel->jsRegistrarsDependencies()
),
GIVE_VERSION,
true
);
Language::setScriptTranslations($registrarsScriptHandle);
/**
* @since 3.1.0 set translations for scripts
* @since 3.0.0
* Using `wp_enqueue_script` instead of `new EnqueueScript` for more control over dependencies.
* The `EnqueueScript` class discovers the dependencies from the associated `asset.php` file,
* which might include dependencies that are not supported in some version of WordPress.
* @link https://github.com/impress-org/givewp-next-gen/pull/181#discussion_r1202686731
*/
Hooks::doAction('givewp_form_builder_enqueue_scripts');
$formBuilderScriptPath = '@givewp/form-builder/script';
wp_enqueue_script(
'@givewp/form-builder/script',
$formBuilderViewModel->jsPathFromPluginRoot(),
$this->getRegisteredFormBuilderJsDependencies(
$formBuilderViewModel->jsDependencies()
),
GIVE_VERSION,
true
);
Language::setScriptTranslations($formBuilderScriptPath);
wp_add_inline_script(
'@givewp/form-builder/script',
'window.giveStorageData = ' . json_encode($formBuilderViewModel->storageData($donationFormId)) . ';',
'before'
);
wp_localize_script('@givewp/form-builder/script', 'onboardingTourData', [
'actionUrl' => admin_url('admin-ajax.php?action=givewp_tour_completed'),
'autoStartDesignTour' => !get_user_meta(get_current_user_id(), 'givewp-form-builder-design-tour-completed', true),
'autoStartSchemaTour' => !get_user_meta(get_current_user_id(), 'givewp-form-builder-schema-tour-completed', true),
]);
$migratedFormId = give_get_meta($donationFormId, 'migratedFormId', true);
$transferredFormId = give_get_meta($donationFormId, 'transferredFormId', true);
$showTransferModal = isset($_GET['showTransfer']) && (bool)$migratedFormId && !(bool)$transferredFormId;
wp_localize_script('@givewp/form-builder/script', 'migrationOnboardingData', [
'pluginUrl' => GIVE_PLUGIN_URL,
'formId' => $donationFormId,
'migrationActionUrl' => admin_url('admin-ajax.php?action=givewp_migration_hide_notice'),
'transferActionUrl' => admin_url('admin-ajax.php?action=givewp_transfer_hide_notice'),
'apiRoot' => esc_url_raw(rest_url('give-api/v2/admin/forms')),
'apiNonce' => wp_create_nonce('wp_rest'),
'isMigratedForm' => $migratedFormId,
'isTransferredForm' => $transferredFormId,
'showUpgradeDialog' => !$showTransferModal && (bool)$migratedFormId && !(bool)give_get_meta(
$donationFormId,
'givewp-form-builder-migration-hide-notice',
true
),
'showTransferModal' => $showTransferModal,
'transferShowNotice' => (bool)$migratedFormId && !(bool)$transferredFormId && !(bool)give_get_meta(
$donationFormId,
'givewp-form-builder-transfer-hide-notice',
true
),
]);
wp_localize_script('@givewp/form-builder/script', 'goalNotificationData', [
'actionUrl' => admin_url('admin-ajax.php?action=givewp_goal_hide_notice'),
'isDismissed' => get_user_meta(get_current_user_id(), 'givewp-goal-notice-dismissed', true),
]);
/**
* @since 3.16.2
*/
wp_localize_script('@givewp/form-builder/script', 'additionalPaymentGatewaysNotificationData', [
'actionUrl' => admin_url('admin-ajax.php?action=givewp_additional_payment_gateways_hide_notice'),
'isDismissed' => get_user_meta(get_current_user_id(), 'givewp-additional-payment-gateways-notice-dismissed', true),
]);
/**
* @since 4.14.2 updated logic with filter
* @since 4.0.0
*/
$campaignUrl = '';
if ($campaign = Campaign::findByFormId($donationFormId)) {
$campaignUrl = admin_url('edit.php?post_type=give_forms&page=give-campaigns&id=' . $campaign->id);
}
/**
* Filters the campaign URL displayed in the form builder header.
* Allows add-ons (e.g., P2P) to provide their own campaign URL when
* the form belongs to a non-core campaign type.
*
* @since 4.14.2
*
* @param string $campaignUrl - The campaign admin URL, or empty string if not found.
* @param int $donationFormId - The donation form ID being edited.
*/
$campaignUrl = apply_filters('givewp_form_builder_campaign_url', $campaignUrl, $donationFormId);
if ($campaignUrl) {
wp_localize_script('@givewp/form-builder/script', 'headerContainer', [
'campaignUrl' => $campaignUrl,
]);
}
View::render('FormBuilder.admin-form-builder');
}
/**
* Load Gutenberg scripts and styles from core.
*
* @see https://github.com/Automattic/isolated-block-editor/blob/trunk/examples/wordpress-php/iso-gutenberg.php
*
* @since 3.0.0
*/
public function loadGutenbergScripts()
{
wp_enqueue_editor();
// Gutenberg scripts
wp_enqueue_script('wp-block-library');
wp_enqueue_script('wp-format-library');
wp_enqueue_script('wp-editor');
// Gutenberg styles
wp_enqueue_style('wp-edit-post');
wp_enqueue_style('wp-format-library');
}
/**
* Loop through the form builder js dependencies and check if they are registered before adding to enqueue_script.
*
* @since 3.0.0
*/
protected function getRegisteredFormBuilderJsDependencies(array $formBuilderJsDependencies): array
{
$scripts = wp_scripts();
return array_filter($formBuilderJsDependencies, static function ($dependency) use ($scripts) {
$isRegistered = $scripts->query($dependency, 'registered');
if (!$isRegistered) {
Log::error(
sprintf(
'Script %s is not registered. Please check the script dependencies.',
$dependency
)
);
}
return $isRegistered;
});
}
}