File Editor
Directories:
.. (Back)
traits
Files:
accordion.php
alert.php
audio.php
button.php
common.php
counter.php
divider.php
google-maps.php
heading.php
html.php
icon-box.php
icon-list.php
icon.php
image-box.php
image-carousel.php
image-gallery.php
image.php
inner-section.php
menu-anchor.php
progress.php
rating.php
read-more.php
share-buttons.php
shortcode.php
sidebar.php
social-icons.php
spacer.php
star-rating.php
tabs.php
testimonial.php
text-editor.php
toggle.php
video.php
wordpress.php
Create New File
Create
Edit File: shortcode.php
<?php namespace Elementor; if ( ! defined( 'ABSPATH' ) ) { exit; // Exit if accessed directly. } /** * Elementor shortcode widget. * * Elementor widget that insert any shortcodes into the page. * * @since 1.0.0 */ class Widget_Shortcode extends Widget_Base { /** * Get widget name. * * Retrieve shortcode widget name. * * @since 1.0.0 * @access public * * @return string Widget name. */ public function get_name() { return 'shortcode'; } /** * Get widget title. * * Retrieve shortcode widget title. * * @since 1.0.0 * @access public * * @return string Widget title. */ public function get_title() { return esc_html__( 'Shortcode', 'elementor' ); } /** * Get widget icon. * * Retrieve shortcode widget icon. * * @since 1.0.0 * @access public * * @return string Widget icon. */ public function get_icon() { return 'eicon-shortcode'; } /** * Get widget keywords. * * Retrieve the list of keywords the widget belongs to. * * @since 2.1.0 * @access public * * @return array Widget keywords. */ public function get_keywords() { return [ 'shortcode', 'code' ]; } /** * Whether the reload preview is required or not. * * Used to determine whether the reload preview is required. * * @since 1.0.0 * @access public * * @return bool Whether the reload preview is required. */ public function is_reload_preview_required() { return true; } /** * Register shortcode widget controls. * * Adds different input fields to allow the user to change and customize the widget settings. * * @since 3.1.0 * @access protected */ protected function register_controls() { $this->start_controls_section( 'section_shortcode', [ 'label' => esc_html__( 'Shortcode', 'elementor' ), ] ); $this->add_control( 'shortcode', [ 'label' => esc_html__( 'Enter your shortcode', 'elementor' ), 'type' => Controls_Manager::TEXTAREA, 'dynamic' => [ 'active' => true, ], 'ai' => [ 'active' => false, ], 'placeholder' => '[gallery id="123" size="medium"]', 'default' => '', ] ); $this->end_controls_section(); } /** * Render shortcode widget output on the frontend. * * Written in PHP and used to generate the final HTML. * * @since 1.0.0 * @access protected */ protected function render() { $shortcode = $this->get_settings_for_display( 'shortcode' ); if ( empty( $shortcode ) ) { return; } $shortcode = do_shortcode( shortcode_unautop( $shortcode ) ); ?> <div class="elementor-shortcode"><?php echo $shortcode; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?></div> <?php } /** * Render shortcode widget as plain content. * * Override the default behavior by printing the shortcode instead of rendering it. * * @since 1.0.0 * @access public */ public function render_plain_content() { // In plain mode, render without shortcode $this->print_unescaped_setting( 'shortcode' ); } /** * Render shortcode widget output in the editor. * * Written as a Backbone JavaScript template and used to generate the live preview. * * @since 2.9.0 * @access protected */ protected function content_template() {} }
Save Changes
Rename File
Rename