848 lines
32 KiB
PHP
848 lines
32 KiB
PHP
<?php
|
|
/**
|
|
* Add a syntax highlter element to fusion-builder.
|
|
*
|
|
* @package fusion-builder
|
|
* @since 1.5
|
|
*/
|
|
|
|
if ( fusion_is_element_enabled( 'fusion_syntax_highlighter' ) ) {
|
|
|
|
if ( ! class_exists( 'FusionSC_Syntax_Highlighter' ) ) {
|
|
/**
|
|
* Shortcode class.
|
|
*
|
|
* @package fusion-builder
|
|
* @since 1.5
|
|
*/
|
|
class FusionSC_Syntax_Highlighter extends Fusion_Element {
|
|
|
|
/**
|
|
* The element counter.
|
|
*
|
|
* @access private
|
|
* @since 1.5
|
|
* @var int
|
|
*/
|
|
private $counter = 1;
|
|
|
|
/**
|
|
* Constructor.
|
|
*
|
|
* @access public
|
|
* @since 1.5
|
|
*/
|
|
public function __construct() {
|
|
parent::__construct();
|
|
|
|
add_filter( 'fusion_attr_syntax-highlighter-container', [ $this, 'syntax_highlighter_container_attr' ] );
|
|
add_filter( 'fusion_attr_syntax-highlighter-textarea', [ $this, 'syntax_highlighter_textarea_attr' ] );
|
|
add_filter( 'fusion_attr_syntax-highlighter-copy-code-title', [ $this, 'syntax_highlighter_copy_code_title_attr' ] );
|
|
|
|
add_shortcode( 'fusion_syntax_highlighter', [ $this, 'render' ] );
|
|
}
|
|
|
|
/**
|
|
* Gets the default values.
|
|
*
|
|
* @static
|
|
* @access public
|
|
* @since 2.0.0
|
|
* @return array
|
|
*/
|
|
public static function get_element_defaults() {
|
|
$fusion_settings = awb_get_fusion_settings();
|
|
|
|
return [
|
|
'border_style' => $fusion_settings->get( 'syntax_highlighter_border_style' ),
|
|
'border_size' => $fusion_settings->get( 'syntax_highlighter_border_size' ),
|
|
'border_color' => $fusion_settings->get( 'syntax_highlighter_border_color' ),
|
|
'background_color' => $fusion_settings->get( 'syntax_highlighter_background_color' ),
|
|
'class' => '',
|
|
'copy_to_clipboard' => $fusion_settings->get( 'syntax_highlighter_copy_to_clipboard' ),
|
|
'copy_to_clipboard_text' => $fusion_settings->get( 'syntax_highlighter_copy_to_clipboard_text' ),
|
|
'font_size' => $fusion_settings->get( 'syntax_highlighter_font_size' ),
|
|
'hide_on_mobile' => fusion_builder_default_visibility( 'string' ),
|
|
'id' => '',
|
|
'language' => '',
|
|
'line_numbers' => $fusion_settings->get( 'syntax_highlighter_line_numbers' ),
|
|
'line_number_background_color' => $fusion_settings->get( 'syntax_highlighter_line_number_background_color' ),
|
|
'line_number_text_color' => $fusion_settings->get( 'syntax_highlighter_line_number_text_color' ),
|
|
'line_wrapping' => $fusion_settings->get( 'syntax_highlighter_line_wrapping' ),
|
|
'margin_top' => $fusion_settings->get( 'syntax_highlighter_margin', 'top' ),
|
|
'margin_left' => $fusion_settings->get( 'syntax_highlighter_margin', 'left' ),
|
|
'margin_bottom' => $fusion_settings->get( 'syntax_highlighter_margin', 'bottom' ),
|
|
'margin_right' => $fusion_settings->get( 'syntax_highlighter_margin', 'right' ),
|
|
'theme' => $fusion_settings->get( 'syntax_highlighter_theme' ),
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Maps settings to param variables.
|
|
*
|
|
* @static
|
|
* @access public
|
|
* @since 2.0.0
|
|
* @return array
|
|
*/
|
|
public static function settings_to_params() {
|
|
|
|
return [
|
|
'syntax_highlighter_border_style' => 'border_style',
|
|
'syntax_highlighter_border_size' => 'border_size',
|
|
'syntax_highlighter_border_color' => 'border_color',
|
|
'syntax_highlighter_background_color' => 'background_color',
|
|
'syntax_highlighter_copy_to_clipboard' => 'copy_to_clipboard',
|
|
'syntax_highlighter_copy_to_clipboard_text' => 'copy_to_clipboard_text',
|
|
'syntax_highlighter_font_size' => 'font_size',
|
|
'syntax_highlighter_line_numbers' => 'line_numbers',
|
|
'syntax_highlighter_line_number_background_color' => 'line_number_background_color',
|
|
'syntax_highlighter_line_number_text_color' => 'line_number_text_color',
|
|
'syntax_highlighter_line_wrapping' => 'line_wrapping',
|
|
'syntax_highlighter_margin[top]' => 'margin_top',
|
|
'syntax_highlighter_margin[left]' => 'margin_left',
|
|
'syntax_highlighter_margin[right]' => 'margin_right',
|
|
'syntax_highlighter_margin[bottom]' => 'margin_bottom',
|
|
'syntax_highlighter_theme' => 'theme',
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Used to set any other variables for use on front-end editor template.
|
|
*
|
|
* @static
|
|
* @access public
|
|
* @since 2.0.0
|
|
* @return array
|
|
*/
|
|
public static function get_element_extras() {
|
|
$fusion_settings = awb_get_fusion_settings();
|
|
return [
|
|
'syntax_highlighter_background_color' => $fusion_settings->get( 'syntax_highlighter_background_color' ),
|
|
'wp_enqueue_code_editor' => function_exists( 'wp_enqueue_code_editor' ),
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Maps settings to extra variables.
|
|
*
|
|
* @static
|
|
* @access public
|
|
* @since 2.0.0
|
|
* @return array
|
|
*/
|
|
public static function settings_to_extras() {
|
|
|
|
return [
|
|
'syntax_highlighter_background_color' => 'syntax_highlighter_background_color',
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Render the shortcode.
|
|
*
|
|
* @access public
|
|
* @since 1.5
|
|
* @param array $args Shortcode parameters.
|
|
* @param string $content Content between shortcode.
|
|
* @return string Highlighted code.
|
|
*/
|
|
public function render( $args, $content = '' ) {
|
|
|
|
$defaults = FusionBuilder::set_shortcode_defaults( self::get_element_defaults(), $args, 'fusion_syntax_highlighter' );
|
|
$content = apply_filters( 'fusion_shortcode_content', $content, 'fusion_syntax_highlighter', $args );
|
|
|
|
// Validate margin values.
|
|
$defaults['margin_top'] = FusionBuilder::validate_shortcode_attr_value( $defaults['margin_top'], 'px' );
|
|
$defaults['margin_left'] = FusionBuilder::validate_shortcode_attr_value( $defaults['margin_left'], 'px' );
|
|
$defaults['margin_bottom'] = FusionBuilder::validate_shortcode_attr_value( $defaults['margin_bottom'], 'px' );
|
|
$defaults['margin_right'] = FusionBuilder::validate_shortcode_attr_value( $defaults['margin_right'], 'px' );
|
|
|
|
// Validate border size value.
|
|
$defaults['border_size'] = FusionBuilder::validate_shortcode_attr_value( $defaults['border_size'], 'px' );
|
|
|
|
// Validate font size value.
|
|
$defaults['font_size'] = FusionBuilder::validate_shortcode_attr_value( $defaults['font_size'], 'px' );
|
|
|
|
$defaults = apply_filters( 'fusion_builder_default_args', $defaults, 'fusion_syntax_highlighter', $args );
|
|
|
|
$this->args = $defaults;
|
|
|
|
$content = fusion_decode_if_needed( $content );
|
|
|
|
// Remove <br> tags added by WP from the code.
|
|
$content = str_replace( '<br />', '', $content );
|
|
|
|
$html = '<div ' . FusionBuilder::attributes( 'syntax-highlighter-container' ) . '>';
|
|
|
|
if ( 'yes' === $this->args['copy_to_clipboard'] ) {
|
|
$html .= '<div ' . FusionBuilder::attributes( 'syntax-highlighter-copy-code' ) . '>';
|
|
$html .= '<span ' . FusionBuilder::attributes( 'syntax-highlighter-copy-code-title' ) . '>' . $this->args['copy_to_clipboard_text'] . '</span>';
|
|
$html .= '</div>';
|
|
}
|
|
|
|
// Enqueue code editor and settings for manipulating CSS.
|
|
if ( function_exists( 'wp_enqueue_code_editor' ) ) {
|
|
wp_enqueue_code_editor( [] );
|
|
|
|
$type = in_array( $this->args['language'], [ 'json', 'xml' ], true ) ? 'application' : 'text';
|
|
|
|
// Get CodeMirror options.
|
|
$settings = [];
|
|
$settings['readOnly'] = 'nocursor';
|
|
$settings['lineNumbers'] = ( 'yes' === $this->args['line_numbers'] ) ? true : false;
|
|
$settings['lineWrapping'] = ( 'break' === $this->args['line_wrapping'] ) ? true : false;
|
|
$settings['theme'] = $this->args['theme'];
|
|
|
|
if ( isset( $this->args['language'] ) && '' !== $this->args['language'] ) {
|
|
$settings['mode'] = $type . '/' . $this->args['language'];
|
|
}
|
|
|
|
$html .= '<label for="fusion_syntax_highlighter_' . $this->counter . '" class="screen-reader-text">' . esc_html__( 'Syntax Highlighter', 'fusion-builder' ) . '</label>';
|
|
$html .= '<textarea ' . FusionBuilder::attributes( 'syntax-highlighter-textarea', $settings ) . '>' . $content . '</textarea>';
|
|
} else {
|
|
// Compatibility for WP < 4.9.
|
|
$html .= '<pre id="fusion_syntax_highlighter_' . $this->counter . '">' . $content . '</pre>';
|
|
}
|
|
$html .= '</div>';
|
|
|
|
$style = '<style type="text/css" scopped="scopped">';
|
|
|
|
if ( $this->args['background_color'] ) {
|
|
$style .= '.fusion-syntax-highlighter-' . $this->counter . ' > .CodeMirror, .fusion-syntax-highlighter-' . $this->counter . ' > .CodeMirror .CodeMirror-gutters {' . sprintf( 'background-color:%s;', $this->args['background_color'] ) . '}';
|
|
}
|
|
|
|
if ( 'no' !== $this->args['line_numbers'] ) {
|
|
$style .= '.fusion-syntax-highlighter-' . $this->counter . ' > .CodeMirror .CodeMirror-gutters { background-color: ' . $this->args['line_number_background_color'] . '; }';
|
|
$style .= '.fusion-syntax-highlighter-' . $this->counter . ' > .CodeMirror .CodeMirror-linenumber { color: ' . $this->args['line_number_text_color'] . '; }';
|
|
}
|
|
|
|
$style .= '</style>';
|
|
|
|
$html = $style . $html;
|
|
|
|
$this->counter++;
|
|
|
|
$this->on_render();
|
|
|
|
return apply_filters( 'fusion_element_syntax_highlighter_content', $html, $args );
|
|
}
|
|
|
|
/**
|
|
* Builds the attributes array.
|
|
*
|
|
* @access public
|
|
* @since 1.5
|
|
* @return array
|
|
*/
|
|
public function syntax_highlighter_container_attr() {
|
|
$attr = [
|
|
'class' => 'fusion-syntax-highlighter-container',
|
|
'style' => 'opacity:0;',
|
|
];
|
|
|
|
$attr['class'] .= ' fusion-syntax-highlighter-' . $this->counter;
|
|
|
|
$theme = ( 'default' === $this->args['theme'] || 'elegant' === $this->args['theme'] ) ? 'light' : 'dark';
|
|
|
|
$attr['class'] .= ' fusion-syntax-highlighter-theme-' . $theme;
|
|
|
|
$attr = fusion_builder_visibility_atts( $this->args['hide_on_mobile'], $attr );
|
|
|
|
if ( $this->args['class'] ) {
|
|
$attr['class'] .= ' ' . $this->args['class'];
|
|
}
|
|
|
|
if ( $this->args['id'] ) {
|
|
$attr['id'] = $this->args['id'];
|
|
}
|
|
|
|
$attr['style'] .= Fusion_Builder_Margin_Helper::get_margins_style( $this->args );
|
|
|
|
if ( $this->args['font_size'] ) {
|
|
$attr['style'] .= 'font-size:' . $this->args['font_size'] . ';';
|
|
}
|
|
|
|
if ( '' !== $this->args['border_size'] ) {
|
|
$attr['style'] .= 'border-width:' . $this->args['border_size'] . ';';
|
|
|
|
if ( $this->args['border_style'] ) {
|
|
$attr['style'] .= 'border-style:' . $this->args['border_style'] . ';';
|
|
}
|
|
|
|
if ( $this->args['border_color'] ) {
|
|
$attr['style'] .= 'border-color:' . $this->args['border_color'] . ';';
|
|
}
|
|
}
|
|
|
|
// Compatibility for WP < 4.9.
|
|
if ( ! function_exists( 'wp_enqueue_code_editor' ) && $this->args['background_color'] ) {
|
|
$attr['style'] .= 'background-color:' . $this->args['background_color'] . ';';
|
|
$attr['style'] .= 'padding:0 1em;';
|
|
}
|
|
|
|
return $attr;
|
|
}
|
|
|
|
/**
|
|
* Builds the attributes array.
|
|
*
|
|
* @access public
|
|
* @since 1.5
|
|
* @param array $settings Highlighter settings for CodeMirror.
|
|
* @return array
|
|
*/
|
|
public function syntax_highlighter_textarea_attr( $settings ) {
|
|
$attr = [
|
|
'class' => 'fusion-syntax-highlighter-textarea',
|
|
'id' => 'fusion_syntax_highlighter_' . $this->counter,
|
|
'style' => '',
|
|
];
|
|
|
|
foreach ( $settings as $setting => $value ) {
|
|
$attr[ 'data-' . $setting ] = $value;
|
|
}
|
|
|
|
return $attr;
|
|
}
|
|
|
|
/**
|
|
* Builds the attributes array.
|
|
*
|
|
* @access public
|
|
* @since 1.5
|
|
* @return array
|
|
*/
|
|
public function syntax_highlighter_copy_code_title_attr() {
|
|
$attr = [
|
|
'class' => 'syntax-highlighter-copy-code-title',
|
|
'data-id' => 'fusion_syntax_highlighter_' . $this->counter,
|
|
'style' => '',
|
|
];
|
|
|
|
if ( $this->args['font_size'] ) {
|
|
$attr['style'] .= 'font-size:' . $this->args['font_size'] . ';';
|
|
}
|
|
|
|
return $attr;
|
|
}
|
|
|
|
/**
|
|
* Sets the necessary scripts.
|
|
*
|
|
* @access public
|
|
* @since 3.2
|
|
* @return void
|
|
*/
|
|
public function on_first_render() {
|
|
Fusion_Dynamic_JS::enqueue_script(
|
|
'fusion-syntax-highlighter',
|
|
FusionBuilder::$js_folder_url . '/general/fusion-syntax-highlighter.js',
|
|
FusionBuilder::$js_folder_path . '/general/fusion-syntax-highlighter.js',
|
|
[ 'jquery' ],
|
|
FUSION_BUILDER_VERSION,
|
|
true
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Load base CSS.
|
|
*
|
|
* @access public
|
|
* @since 3.0
|
|
* @return void
|
|
*/
|
|
public function add_css_files() {
|
|
FusionBuilder()->add_element_css( FUSION_BUILDER_PLUGIN_DIR . 'assets/css/shortcodes/syntax-highlighter.min.css' );
|
|
}
|
|
|
|
/**
|
|
* Adds settings to element options panel.
|
|
*
|
|
* @access public
|
|
* @since 1.5
|
|
* @return array $sections Syntax highlighter settings.
|
|
*/
|
|
public function add_options() {
|
|
$fusion_settings = awb_get_fusion_settings();
|
|
|
|
$code_mirror_themes = apply_filters(
|
|
'fusion_syntax_highlighter_themes',
|
|
[
|
|
'default' => esc_attr__( 'Light 1', 'fusion-builder' ),
|
|
'elegant' => esc_attr__( 'Light 2', 'fusion-builder' ),
|
|
'hopscotch' => esc_attr__( 'Dark 1', 'fusion-builder' ),
|
|
'oceanic-next' => esc_attr__( 'Dark 2', 'fusion-builder' ),
|
|
]
|
|
);
|
|
|
|
return [
|
|
'syntax_highlighter_shortcode_section' => [
|
|
'label' => esc_attr__( 'Syntax Highlighter', 'fusion-builder' ),
|
|
'description' => '',
|
|
'id' => 'syntax_highlighter_shortcode_section',
|
|
'default' => '',
|
|
'type' => 'accordion',
|
|
'icon' => 'fusiona-code',
|
|
'fields' => [
|
|
'syntax_highlighter_theme' => [
|
|
'type' => 'radio-buttonset',
|
|
'label' => esc_attr__( 'Highlighter Theme', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Select which theme you want to use for code highlighting.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_theme',
|
|
'choices' => $code_mirror_themes,
|
|
'default' => 'default',
|
|
'transport' => 'postMessage',
|
|
],
|
|
'syntax_highlighter_line_numbers' => [
|
|
'type' => 'radio-buttonset',
|
|
'label' => esc_attr__( 'Line Numbers', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Choose if you want to display or hide line numbers.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_line_numbers',
|
|
'transport' => 'postMessage',
|
|
'choices' => [
|
|
'yes' => esc_attr__( 'Yes', 'fusion-builder' ),
|
|
'no' => esc_attr__( 'No', 'fusion-builder' ),
|
|
],
|
|
'default' => 'yes',
|
|
],
|
|
'syntax_highlighter_line_number_background_color' => [
|
|
'type' => 'color-alpha',
|
|
'label' => esc_attr__( 'Line Numbers Background Color', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the background color for the line numbers. If left empty, color from selected theme will be used.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_line_number_background_color',
|
|
'default' => 'var(--awb-color2)',
|
|
'transport' => 'postMessage',
|
|
'required' => [
|
|
[
|
|
'setting' => 'syntax_highlighter_line_numbers',
|
|
'value' => 'yes',
|
|
'operator' => '==',
|
|
],
|
|
],
|
|
],
|
|
'syntax_highlighter_line_number_text_color' => [
|
|
'type' => 'color-alpha',
|
|
'label' => esc_attr__( 'Line Numbers Text Color', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the color for line number text. If left empty, color from selected theme will be used.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_line_number_text_color',
|
|
'default' => 'var(--awb-color8)',
|
|
'transport' => 'postMessage',
|
|
'required' => [
|
|
[
|
|
'setting' => 'syntax_highlighter_line_numbers',
|
|
'value' => 'yes',
|
|
'operator' => '==',
|
|
],
|
|
],
|
|
],
|
|
'syntax_highlighter_line_wrapping' => [
|
|
'type' => 'radio-buttonset',
|
|
'label' => esc_attr__( 'Line Wrapping', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls whether the long line should break or add horizontal scroll.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_line_wrapping',
|
|
'transport' => 'postMessage',
|
|
'choices' => [
|
|
'scroll' => esc_attr__( 'Scroll', 'fusion-builder' ),
|
|
'break' => esc_attr__( 'Break', 'fusion-builder' ),
|
|
],
|
|
'default' => 'scroll',
|
|
],
|
|
'syntax_highlighter_copy_to_clipboard' => [
|
|
'type' => 'radio-buttonset',
|
|
'label' => esc_attr__( 'Copy to Clipboard', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Choose if you want to allow your visitors to easily copy your code with a click of the button.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_copy_to_clipboard',
|
|
'transport' => 'postMessage',
|
|
'choices' => [
|
|
'yes' => esc_attr__( 'Yes', 'fusion-builder' ),
|
|
'no' => esc_attr__( 'No', 'fusion-builder' ),
|
|
],
|
|
'default' => 'yes',
|
|
],
|
|
'syntax_highlighter_copy_to_clipboard_text' => [
|
|
'type' => 'text',
|
|
'label' => esc_attr__( 'Copy to Clipboard Text', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Enter text to be displayed for user to click to copy.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_copy_to_clipboard_text',
|
|
'default' => esc_attr__( 'Copy to Clipboard', 'fusion-builder' ),
|
|
'transport' => 'postMessage',
|
|
'required' => [
|
|
[
|
|
'setting' => 'syntax_highlighter_copy_to_clipboard',
|
|
'value' => 'yes',
|
|
'operator' => '==',
|
|
],
|
|
],
|
|
],
|
|
'syntax_highlighter_font_size' => [
|
|
'type' => 'slider',
|
|
'label' => esc_attr__( 'Font Size', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the font size of the syntax highlight code.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_font_size',
|
|
'default' => '14',
|
|
'transport' => 'postMessage',
|
|
'choices' => [
|
|
'min' => '10',
|
|
'max' => '100',
|
|
'step' => '1',
|
|
],
|
|
],
|
|
'syntax_highlighter_background_color' => [
|
|
'type' => 'color-alpha',
|
|
'label' => esc_attr__( 'Background Color', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the background color for code highlight area.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_background_color',
|
|
'transport' => 'postMessage',
|
|
'default' => 'var(--awb-color1)',
|
|
],
|
|
'syntax_highlighter_border_size' => [
|
|
'type' => 'slider',
|
|
'label' => esc_attr__( 'Border Size', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the border size of the syntax highlighter. In pixels.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_border_size',
|
|
'default' => '1',
|
|
'transport' => 'postMessage',
|
|
'choices' => [
|
|
'min' => '0',
|
|
'max' => '50',
|
|
'step' => '1',
|
|
],
|
|
],
|
|
'syntax_highlighter_border_color' => [
|
|
'type' => 'color-alpha',
|
|
'label' => esc_attr__( 'Border Color', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the border color.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_border_color',
|
|
'default' => 'var(--awb-color3)',
|
|
'transport' => 'postMessage',
|
|
'required' => [
|
|
[
|
|
'setting' => 'syntax_highlighter_border_size',
|
|
'value' => '0',
|
|
'operator' => '!=',
|
|
],
|
|
],
|
|
],
|
|
'syntax_highlighter_border_style' => [
|
|
'type' => 'radio-buttonset',
|
|
'label' => esc_attr__( 'Border Style', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the border style.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_border_style',
|
|
'default' => 'solid',
|
|
'transport' => 'postMessage',
|
|
'required' => [
|
|
[
|
|
'setting' => 'syntax_highlighter_border_size',
|
|
'value' => '0',
|
|
'operator' => '!=',
|
|
],
|
|
],
|
|
'choices' => [
|
|
'solid' => esc_attr__( 'Solid', 'fusion-builder' ),
|
|
'dashed' => esc_attr__( 'Dashed', 'fusion-builder' ),
|
|
'dotted' => esc_attr__( 'Dotted', 'fusion-builder' ),
|
|
],
|
|
],
|
|
'syntax_highlighter_margin' => [
|
|
'label' => esc_html__( 'Margins', 'fusion-builder' ),
|
|
'description' => esc_html__( 'Controls the margin around syntax highlighter element.', 'fusion-builder' ),
|
|
'id' => 'syntax_highlighter_margin',
|
|
'type' => 'spacing',
|
|
'transport' => 'postMessage',
|
|
'choices' => [
|
|
'top' => true,
|
|
'left' => true,
|
|
'bottom' => true,
|
|
'right' => true,
|
|
],
|
|
'default' => [
|
|
'top' => '0px',
|
|
'left' => '0px',
|
|
'bottom' => '0px',
|
|
'right' => '0px',
|
|
],
|
|
],
|
|
],
|
|
],
|
|
];
|
|
}
|
|
}
|
|
}
|
|
|
|
new FusionSC_Syntax_Highlighter();
|
|
|
|
}
|
|
|
|
/**
|
|
* Map shortcode to Avada Builder.
|
|
*
|
|
* @since 1.5
|
|
*/
|
|
function fusion_element_syntax_highlighter() {
|
|
$fusion_settings = awb_get_fusion_settings();
|
|
|
|
$code_mirror_themes = apply_filters(
|
|
'fusion_syntax_highlighter_themes',
|
|
[
|
|
'' => esc_attr__( 'Default', 'fusion-builder' ),
|
|
'default' => esc_attr__( 'Light 1', 'fusion-builder' ),
|
|
'elegant' => esc_attr__( 'Light 2', 'fusion-builder' ),
|
|
'hopscotch' => esc_attr__( 'Dark 1', 'fusion-builder' ),
|
|
'oceanic-next' => esc_attr__( 'Dark 2', 'fusion-builder' ),
|
|
]
|
|
);
|
|
|
|
fusion_builder_map(
|
|
fusion_builder_frontend_data(
|
|
'FusionSC_Syntax_Highlighter',
|
|
[
|
|
'name' => esc_attr__( 'Syntax Highlighter', 'fusion-builder' ),
|
|
'shortcode' => 'fusion_syntax_highlighter',
|
|
'icon' => 'fusiona-code',
|
|
'escape_html' => true,
|
|
'help_url' => 'https://avada.com/documentation/syntax-highlighter-element/',
|
|
'params' => [
|
|
[
|
|
'type' => 'code',
|
|
'heading' => esc_attr__( 'Code to Highlight', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Enter some code to be displayed with highlighted syntax.', 'fusion-builder' ),
|
|
'param_name' => 'element_content',
|
|
'value' => '',
|
|
'callback' => [
|
|
'function' => 'fusion_code_mirror',
|
|
],
|
|
],
|
|
[
|
|
'type' => 'radio_button_set',
|
|
'heading' => esc_attr__( 'Highlighter Theme', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Select which theme you want to use for code highlighting.', 'fusion-builder' ),
|
|
'param_name' => 'theme',
|
|
'value' => $code_mirror_themes,
|
|
'default' => '',
|
|
],
|
|
[
|
|
'type' => 'select',
|
|
'heading' => esc_attr__( 'Code Language', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Select the language the code is in.', 'fusion-builder' ),
|
|
'param_name' => 'language',
|
|
'value' => [
|
|
'x-sh' => esc_attr__( 'bash', 'fusion-builder' ),
|
|
'css' => esc_attr__( 'css', 'fusion-builder' ),
|
|
'conf' => esc_attr__( 'conf', 'fusion-builder' ),
|
|
'diff' => esc_attr__( 'diff', 'fusion-builder' ),
|
|
'html' => esc_attr__( 'html', 'fusion-builder' ),
|
|
'htm' => esc_attr__( 'htm', 'fusion-builder' ),
|
|
'http' => esc_attr__( 'http', 'fusion-builder' ),
|
|
'javascript' => esc_attr__( 'javascript', 'fusion-builder' ),
|
|
'json' => esc_attr__( 'json', 'fusion-builder' ),
|
|
'jsx' => esc_attr__( 'jsx', 'fusion-builder' ),
|
|
'x-less' => esc_attr__( 'less', 'fusion-builder' ),
|
|
'md' => esc_attr__( 'md', 'fusion-builder' ),
|
|
'patch' => esc_attr__( 'patch', 'fusion-builder' ),
|
|
'x-php' => esc_attr__( 'php', 'fusion-builder' ),
|
|
'phtml' => esc_attr__( 'phtml', 'fusion-builder' ),
|
|
'x-sass' => esc_attr__( 'sass', 'fusion-builder' ),
|
|
'x-scss' => esc_attr__( 'scss', 'fusion-builder' ),
|
|
'sql' => esc_attr__( 'sql', 'fusion-builder' ),
|
|
'svg' => esc_attr__( 'svg', 'fusion-builder' ),
|
|
'txt' => esc_attr__( 'txt', 'fusion-builder' ),
|
|
'xml' => esc_attr__( 'xml', 'fusion-builder' ),
|
|
'yaml' => esc_attr__( 'yaml', 'fusion-builder' ),
|
|
'yml' => esc_attr__( 'yml', 'fusion-builder' ),
|
|
],
|
|
],
|
|
[
|
|
'type' => 'radio_button_set',
|
|
'heading' => esc_attr__( 'Line Numbers', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Choose if you want to display or hide line numbers.', 'fusion-builder' ),
|
|
'param_name' => 'line_numbers',
|
|
'value' => [
|
|
'' => esc_attr__( 'Default', 'fusion-builder' ),
|
|
'yes' => esc_attr__( 'Yes', 'fusion-builder' ),
|
|
'no' => esc_attr__( 'No', 'fusion-builder' ),
|
|
],
|
|
'default' => '',
|
|
],
|
|
[
|
|
'type' => 'radio_button_set',
|
|
'heading' => esc_attr__( 'Line Wrapping', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls whether the long line should break or add horizontal scroll.', 'fusion-builder' ),
|
|
'param_name' => 'line_wrapping',
|
|
'value' => [
|
|
'' => esc_attr__( 'Default', 'fusion-builder' ),
|
|
'scroll' => esc_attr__( 'Scroll', 'fusion-builder' ),
|
|
'break' => esc_attr__( 'Break', 'fusion-builder' ),
|
|
],
|
|
'default' => '',
|
|
],
|
|
[
|
|
'type' => 'radio_button_set',
|
|
'heading' => esc_attr__( 'Copy to Clipboard', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Choose if you want to allow your visitors to easily copy your code with a click of the button.', 'fusion-builder' ),
|
|
'param_name' => 'copy_to_clipboard',
|
|
'value' => [
|
|
'' => esc_attr__( 'Default', 'fusion-builder' ),
|
|
'yes' => esc_attr__( 'Yes', 'fusion-builder' ),
|
|
'no' => esc_attr__( 'No', 'fusion-builder' ),
|
|
],
|
|
'default' => '',
|
|
],
|
|
[
|
|
'type' => 'textfield',
|
|
'heading' => esc_attr__( 'Copy to Clipboard Text', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Enter text to be displayed for user to click to copy.', 'fusion-builder' ),
|
|
'param_name' => 'copy_to_clipboard_text',
|
|
'dependency' => [
|
|
[
|
|
'element' => 'copy_to_clipboard',
|
|
'value' => 'no',
|
|
'operator' => '!=',
|
|
],
|
|
],
|
|
],
|
|
[
|
|
'type' => 'range',
|
|
'heading' => esc_attr__( 'Font Size', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the font size of the syntax highlight code. In pixels.', 'fusion-builder' ),
|
|
'param_name' => 'font_size',
|
|
'default' => intval( $fusion_settings->get( 'syntax_highlighter_font_size' ) ),
|
|
'value' => '',
|
|
'choices' => [
|
|
'min' => '10',
|
|
'max' => '100',
|
|
'step' => '1',
|
|
],
|
|
'group' => esc_attr__( 'Design', 'fusion-builder' ),
|
|
],
|
|
[
|
|
'type' => 'range',
|
|
'heading' => esc_attr__( 'Border Size', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the border size of the syntax highlighter. In pixels.', 'fusion-builder' ),
|
|
'param_name' => 'border_size',
|
|
'default' => intval( $fusion_settings->get( 'syntax_highlighter_border_size' ) ),
|
|
'value' => '',
|
|
'choices' => [
|
|
'min' => '0',
|
|
'max' => '50',
|
|
'step' => '1',
|
|
],
|
|
'group' => esc_attr__( 'Design', 'fusion-builder' ),
|
|
],
|
|
[
|
|
'type' => 'colorpickeralpha',
|
|
'heading' => esc_attr__( 'Border Color', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the border color.', 'fusion-builder' ),
|
|
'param_name' => 'border_color',
|
|
'value' => '',
|
|
'default' => $fusion_settings->get( 'syntax_highlighter_border_color' ),
|
|
'group' => esc_attr__( 'Design', 'fusion-builder' ),
|
|
'dependency' => [
|
|
[
|
|
'element' => 'border_size',
|
|
'value' => '0',
|
|
'operator' => '!=',
|
|
],
|
|
],
|
|
],
|
|
[
|
|
'type' => 'radio_button_set',
|
|
'heading' => esc_attr__( 'Border Style', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the border style.', 'fusion-builder' ),
|
|
'param_name' => 'border_style',
|
|
'default' => '',
|
|
'group' => esc_attr__( 'Design', 'fusion-builder' ),
|
|
'dependency' => [
|
|
[
|
|
'element' => 'border_size',
|
|
'value' => '0',
|
|
'operator' => '!=',
|
|
],
|
|
],
|
|
'value' => [
|
|
'' => esc_attr__( 'Default', 'fusion-builder' ),
|
|
'solid' => esc_attr__( 'Solid', 'fusion-builder' ),
|
|
'dashed' => esc_attr__( 'Dashed', 'fusion-builder' ),
|
|
'dotted' => esc_attr__( 'Dotted', 'fusion-builder' ),
|
|
],
|
|
],
|
|
[
|
|
'type' => 'colorpickeralpha',
|
|
'heading' => esc_attr__( 'Background Color', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the background color for code highlight area.', 'fusion-builder' ),
|
|
'param_name' => 'background_color',
|
|
'value' => '',
|
|
'default' => $fusion_settings->get( 'syntax_highlighter_background_color' ),
|
|
'group' => esc_attr__( 'Design', 'fusion-builder' ),
|
|
],
|
|
[
|
|
'type' => 'colorpickeralpha',
|
|
'heading' => esc_attr__( 'Line Number Background Color', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the line number background color for code highlight area.', 'fusion-builder' ),
|
|
'param_name' => 'line_number_background_color',
|
|
'value' => '',
|
|
'default' => $fusion_settings->get( 'syntax_highlighter_line_number_background_color' ),
|
|
'dependency' => [
|
|
[
|
|
'element' => 'line_numbers',
|
|
'value' => 'no',
|
|
'operator' => '!=',
|
|
],
|
|
],
|
|
'group' => esc_attr__( 'Design', 'fusion-builder' ),
|
|
],
|
|
[
|
|
'type' => 'colorpickeralpha',
|
|
'heading' => esc_attr__( 'Line Number Text Color', 'fusion-builder' ),
|
|
'description' => esc_attr__( 'Controls the line number text color for code highlight area.', 'fusion-builder' ),
|
|
'param_name' => 'line_number_text_color',
|
|
'value' => '',
|
|
'default' => $fusion_settings->get( 'syntax_highlighter_line_number_text_color' ),
|
|
'dependency' => [
|
|
[
|
|
'element' => 'line_numbers',
|
|
'value' => 'no',
|
|
'operator' => '!=',
|
|
],
|
|
],
|
|
'group' => esc_attr__( 'Design', 'fusion-builder' ),
|
|
],
|
|
'fusion_margin_placeholder' => [
|
|
'param_name' => 'margin',
|
|
'description' => esc_attr__( 'Control spacing around the syntax highlighter. In px, em or %, e.g. 10px.', 'fusion-builder' ),
|
|
'value' => [
|
|
'margin_top' => '',
|
|
'margin_right' => '',
|
|
'margin_bottom' => '',
|
|
'margin_left' => '',
|
|
],
|
|
],
|
|
[
|
|
'type' => 'checkbox_button_set',
|
|
'heading' => esc_attr__( 'Element Visibility', 'fusion-builder' ),
|
|
'param_name' => 'hide_on_mobile',
|
|
'value' => fusion_builder_visibility_options( 'full' ),
|
|
'default' => fusion_builder_default_visibility( 'array' ),
|
|
'description' => esc_attr__( 'Choose to show or hide the element on small, medium or large screens. You can choose more than one at a time.', 'fusion-builder' ),
|
|
],
|
|
[
|
|
'type' => 'textfield',
|
|
'heading' => esc_attr__( 'CSS Class', 'fusion-builder' ),
|
|
'param_name' => 'class',
|
|
'value' => '',
|
|
'description' => esc_attr__( 'Add a class to the wrapping HTML element.', 'fusion-builder' ),
|
|
],
|
|
[
|
|
'type' => 'textfield',
|
|
'heading' => esc_attr__( 'CSS ID', 'fusion-builder' ),
|
|
'param_name' => 'id',
|
|
'value' => '',
|
|
'description' => esc_attr__( 'Add an ID to the wrapping HTML element.', 'fusion-builder' ),
|
|
],
|
|
],
|
|
]
|
|
)
|
|
);
|
|
}
|
|
add_action( 'fusion_builder_before_init', 'fusion_element_syntax_highlighter' );
|