get( 'access' ); if ( ! method_exists( $access, 'get_menu_cap' ) ) { return; } // Default Forms top level menu item. add_menu_page( esc_html__( 'WPForms', 'wpforms-lite' ), esc_html__( 'WPForms', 'wpforms-lite' ), $access->get_menu_cap( 'view_forms' ), 'wpforms-overview', [ $this, 'admin_page' ], 'data:image/svg+xml;base64,' . base64_encode( '' ), apply_filters( 'wpforms_menu_position', '58.9' ) ); // All Forms sub menu item. add_submenu_page( 'wpforms-overview', esc_html__( 'WPForms', 'wpforms-lite' ), esc_html__( 'All Forms', 'wpforms-lite' ), $access->get_menu_cap( 'view_forms' ), 'wpforms-overview', [ $this, 'admin_page' ] ); // Add New sub menu item. add_submenu_page( 'wpforms-overview', esc_html__( 'WPForms Builder', 'wpforms-lite' ), esc_html__( 'Add New', 'wpforms-lite' ), $access->get_menu_cap( [ 'create_forms', 'edit_forms' ] ), 'wpforms-builder', [ $this, 'admin_page' ] ); // Entries sub menu item. add_submenu_page( 'wpforms-overview', esc_html__( 'Form Entries', 'wpforms-lite' ), esc_html__( 'Entries', 'wpforms-lite' ), $access->get_menu_cap( 'view_entries' ), 'wpforms-entries', [ $this, 'admin_page' ] ); // Payments sub menu item. add_submenu_page( 'wpforms-overview', esc_html__( 'Payments', 'wpforms-lite' ), esc_html__( 'Payments', 'wpforms-lite' ) . $this->get_new_badge_html(), $manage_cap, WPForms\Admin\Payments\Payments::SLUG, [ $this, 'admin_page' ] ); do_action_deprecated( 'wpform_admin_menu', [ $this ], '1.5.5 of the WPForms plugin', 'wpforms_admin_menu' ); do_action( 'wpforms_admin_menu', $this ); // Templates sub menu item. add_submenu_page( 'wpforms-overview', esc_html__( 'WPForms Templates', 'wpforms-lite' ), esc_html__( 'Form Templates', 'wpforms-lite' ), $access->get_menu_cap( 'create_forms' ), 'wpforms-templates', [ $this, 'admin_page' ] ); // Settings sub menu item. add_submenu_page( 'wpforms-overview', esc_html__( 'WPForms Settings', 'wpforms-lite' ), esc_html__( 'Settings', 'wpforms-lite' ), $manage_cap, 'wpforms-settings', [ $this, 'admin_page' ] ); // Tools sub menu item. add_submenu_page( 'wpforms-overview', esc_html__( 'WPForms Tools', 'wpforms-lite' ), esc_html__( 'Tools', 'wpforms-lite' ), $access->get_menu_cap( [ 'create_forms', 'view_forms', 'view_entries' ] ), 'wpforms-tools', [ $this, 'admin_page' ] ); // Hidden placeholder paged used for misc content. add_submenu_page( 'wpforms-settings', esc_html__( 'WPForms', 'wpforms-lite' ), esc_html__( 'Info', 'wpforms-lite' ), $access->get_menu_cap( 'any' ), 'wpforms-page', [ $this, 'admin_page' ] ); // Addons submenu page. add_submenu_page( 'wpforms-overview', esc_html__( 'WPForms Addons', 'wpforms-lite' ), '' . esc_html__( 'Addons', 'wpforms-lite' ) . '', $manage_cap, 'wpforms-addons', [ $this, 'admin_page' ] ); // Analytics submenu page. add_submenu_page( 'wpforms-overview', esc_html__( 'Analytics', 'wpforms-lite' ), esc_html__( 'Analytics', 'wpforms-lite' ), $manage_cap, WPForms\Admin\Pages\Analytics::SLUG, [ $this, 'admin_page' ] ); // SMTP submenu page. add_submenu_page( 'wpforms-overview', esc_html__( 'SMTP', 'wpforms-lite' ), esc_html__( 'SMTP', 'wpforms-lite' ), $manage_cap, WPForms\Admin\Pages\SMTP::SLUG, [ $this, 'admin_page' ] ); // About submenu page. add_submenu_page( 'wpforms-overview', esc_html__( 'About WPForms', 'wpforms-lite' ), esc_html__( 'About Us', 'wpforms-lite' ), $access->get_menu_cap( 'any' ), WPForms_About::SLUG, [ $this, 'admin_page' ] ); // Community submenu page. add_submenu_page( 'wpforms-overview', esc_html__( 'Community', 'wpforms-lite' ), esc_html__( 'Community', 'wpforms-lite' ), $manage_cap, WPForms\Admin\Pages\Community::SLUG, [ $this, 'admin_page' ] ); if ( ! wpforms()->is_pro() ) { add_submenu_page( 'wpforms-overview', esc_html__( 'Upgrade to Pro', 'wpforms-lite' ), esc_html__( 'Upgrade to Pro', 'wpforms-lite' ), $manage_cap, wpforms_admin_upgrade_link( 'admin-menu' ) ); } } /** * Hide "Add New" admin menu item if a user can't create forms. * * @since 1.5.8 */ public function hide_wpforms_submenu_items() { if ( wpforms_current_user_can( 'create_forms' ) ) { return; } global $submenu; if ( ! isset( $submenu['wpforms-overview'] ) ) { return; } foreach ( $submenu['wpforms-overview'] as $key => $item ) { if ( isset( $item[2] ) && 'wpforms-builder' === $item[2] ) { unset( $submenu['wpforms-overview'][ $key ] ); break; } } $this->hide_wpforms_menu_item(); } /** * Hide "WPForms" admin menu if it has no submenu items. * * @since 1.5.8 */ public function hide_wpforms_menu_item() { global $submenu, $menu; if ( ! empty( $submenu['wpforms-overview'] ) ) { return; } unset( $submenu['wpforms-overview'] ); foreach ( $menu as $key => $item ) { if ( isset( $item[2] ) && 'wpforms-overview' === $item[2] ) { unset( $menu[ $key ] ); break; } } } /** * Alias method for backward compatibility. * * @since 1.7.4 * @deprecated 1.7.8 */ public function style_upgrade_pro_link() { _deprecated_function( __METHOD__, '1.7.8 of the WPForms plugin', __CLASS__ . '::adjust_pro_menu_item()' ); $this->adjust_pro_menu_item(); } /** * Add the PRO badge to left sidebar menu item. * * @since 1.7.8 * @deprecated 1.8.1 */ public function adjust_pro_menu_item_class() { _deprecated_function( __METHOD__, '1.8.1 of the WPForms plugin', __CLASS__ . '::adjust_pro_menu_item()' ); $this->adjust_pro_menu_item(); } /** * Make changes to the PRO menu item. * * @since 1.8.1 */ public function adjust_pro_menu_item() { global $submenu; // Bail if plugin menu is not registered. if ( ! isset( $submenu['wpforms-overview'] ) ) { return; } $upgrade_link_position = key( array_filter( $submenu['wpforms-overview'], static function( $item ) { return strpos( $item[2], 'https://wpforms.com/lite-upgrade' ) !== false; } ) ); // Bail if "Upgrade to Pro" menu item is not registered. if ( $upgrade_link_position === null ) { return; } // Add the PRO badge to the menu item. // phpcs:disable WordPress.WP.GlobalVariablesOverride.Prohibited if ( isset( $submenu['wpforms-overview'][ $upgrade_link_position ][4] ) ) { $submenu['wpforms-overview'][ $upgrade_link_position ][4] .= ' wpforms-sidebar-upgrade-pro'; } else { $submenu['wpforms-overview'][ $upgrade_link_position ][] = 'wpforms-sidebar-upgrade-pro'; } $current_screen = get_current_screen(); $upgrade_utm_content = $current_screen === null ? 'Upgrade to Pro' : 'Upgrade to Pro - ' . $current_screen->base; // phpcs:ignore WordPress.Security.NonceVerification.Recommended $upgrade_utm_content = empty( $_GET['view'] ) ? $upgrade_utm_content : $upgrade_utm_content . ': ' . sanitize_key( $_GET['view'] ); // Add utm_content to the menu item. $submenu['wpforms-overview'][ $upgrade_link_position ][2] = esc_url( add_query_arg( 'utm_content', $upgrade_utm_content, $submenu['wpforms-overview'][ $upgrade_link_position ][2] ) ); // phpcs:enable WordPress.WP.GlobalVariablesOverride.Prohibited } /** * Wrapper for the hook to render our custom settings pages. * * @since 1.0.0 */ public function admin_page() { do_action( 'wpforms_admin_page' ); } /** * Add settings link to the Plugins page. * * @since 1.3.9 * * @param array $links Plugin row links. * @param string $plugin_file Path to the plugin file relative to the plugins directory. * @param array $plugin_data An array of plugin data. See `get_plugin_data()`. * @param string $context The plugin context. * * @return array $links */ public function settings_link( $links, $plugin_file, $plugin_data, $context ) { $custom['pro'] = sprintf( '%3$s', esc_url( wpforms_admin_upgrade_link( 'all-plugins', 'Get WPForms Pro' ) ), esc_attr__( 'Upgrade to WPForms Pro', 'wpforms-lite' ), esc_html__( 'Get WPForms Pro', 'wpforms-lite' ) ); $custom['settings'] = sprintf( '%s', esc_url( add_query_arg( [ 'page' => 'wpforms-settings' ], admin_url( 'admin.php' ) ) ), esc_attr__( 'Go to WPForms Settings page', 'wpforms-lite' ), esc_html__( 'Settings', 'wpforms-lite' ) ); $custom['docs'] = sprintf( '%3$s', esc_url( add_query_arg( [ 'utm_content' => 'Documentation', 'utm_campaign' => 'liteplugin', 'utm_medium' => 'all-plugins', 'utm_source' => 'WordPress', ], 'https://wpforms.com/docs/' ) ), esc_attr__( 'Read the documentation', 'wpforms-lite' ), esc_html__( 'Docs', 'wpforms-lite' ) ); return array_merge( $custom, (array) $links ); } /** * Get the HTML for the "NEW!" badge. * * @since 1.7.8 * * @return string */ private function get_new_badge_html() { return ' NEW!'; } /** * Output inline styles for the admin menu. * * @since 1.7.8 */ public function admin_menu_styles() { $styles = '#adminmenu .wpforms-menu-new { color: #f18500; vertical-align: super; font-size: 9px; font-weight: 600; padding-left: 2px; }'; if ( ! wpforms()->is_pro() ) { $styles .= 'a.wpforms-sidebar-upgrade-pro { background-color: #00a32a !important; color: #fff !important; font-weight: 600 !important; }'; } // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped printf( '', $styles ); } } new WPForms_Admin_Menu();