Create New Item
Item Type
File
Folder
Item Name
Search file in folder and subfolders...
Are you sure want to rename?
File Manager
/
post-date
/
wp-content
/
plugins
/
js_composer
/
include
/
params
/
column_offset
:
column_offset.php
Advanced Search
Upload
New Item
Settings
Back
Back Up
Advanced Editor
Save
<?php if ( ! defined( 'ABSPATH' ) ) { die( '-1' ); } /** * @property mixed data */ class Vc_Column_Offset { /** * @var array */ protected $settings = array(); /** * @var string */ protected $value = ''; /** * @var array */ protected $size_types = array( 'lg' => 'Large', 'md' => 'Medium', 'sm' => 'Small', 'xs' => 'Extra small', ); /** * @var array */ protected $column_width_list = array(); /** * @param $settings * @param $value */ public function __construct( $settings, $value ) { $this->settings = $settings; $this->value = $value; $this->column_width_list = array( esc_html__( '1 column - 1/12', 'js_composer' ) => '1', esc_html__( '2 columns - 1/6', 'js_composer' ) => '2', esc_html__( '3 columns - 1/4', 'js_composer' ) => '3', esc_html__( '4 columns - 1/3', 'js_composer' ) => '4', esc_html__( '5 columns - 5/12', 'js_composer' ) => '5', esc_html__( '6 columns - 1/2', 'js_composer' ) => '6', esc_html__( '7 columns - 7/12', 'js_composer' ) => '7', esc_html__( '8 columns - 2/3', 'js_composer' ) => '8', esc_html__( '9 columns - 3/4', 'js_composer' ) => '9', esc_html__( '10 columns - 5/6', 'js_composer' ) => '10', esc_html__( '11 columns - 11/12', 'js_composer' ) => '11', esc_html__( '12 columns - 1/1', 'js_composer' ) => '12', esc_html__( '20% - 1/5', 'js_composer' ) => '1/5', esc_html__( '40% - 2/5', 'js_composer' ) => '2/5', esc_html__( '60% - 3/5', 'js_composer' ) => '3/5', esc_html__( '80% - 4/5', 'js_composer' ) => '4/5', ); } /** * @return string */ public function render() { ob_start(); vc_include_template( 'params/column_offset/template.tpl.php', array( 'settings' => $this->settings, 'value' => $this->value, 'data' => $this->valueData(), 'sizes' => $this->size_types, 'param' => $this, ) ); return ob_get_clean(); } /** * @return array|mixed */ public function valueData() { if ( ! isset( $this->data ) ) { $this->data = preg_split( '/\s+/', $this->value ); } return $this->data; } /** * @param $size * * @return string */ public function sizeControl( $size ) { if ( 'sm' === $size ) { return '<span class="vc_description">' . esc_html__( 'Default value from width attribute', 'js_composer' ) . '</span>'; } $empty_label = 'xs' === $size ? '' : esc_html__( 'Inherit from smaller', 'js_composer' ); $output = sprintf( '<select name="vc_col_%s_size" class="vc_column_offset_field" data-type="size-%s"><option value="" style="color: #ccc;">%s</option>', $size, $size, $empty_label ); foreach ( $this->column_width_list as $label => $index ) { $value = 'vc_col-' . $size . '-' . $index; $output .= sprintf( '<option value="%s" %s>%s</option>', $value, in_array( $value, $this->data, true ) ? 'selected="true"' : '', $label ); } $output .= '</select>'; return $output; } /** * @param $size * * @return string */ public function offsetControl( $size ) { $prefix = 'vc_col-' . $size . '-offset-'; $empty_label = 'xs' === $size ? esc_html__( 'No offset', 'js_composer' ) : esc_html__( 'Inherit from smaller', 'js_composer' ); $output = sprintf( '<select name="vc_%s_offset_size" class="vc_column_offset_field" data-type="offset-%s"><option value="" style="color: #ccc;">%s</option>', $size, $size, $empty_label ); if ( 'xs' !== $size ) { $output .= sprintf( '<option value="%s0" style="color: #ccc;"%s>%s</option>', $prefix, in_array( $prefix . '0', $this->data, true ) ? ' selected="true"' : '', esc_html__( 'No offset', 'js_composer' ) ); } foreach ( $this->column_width_list as $label => $index ) { $value = $prefix . $index; $output .= sprintf( '<option value="%s"%s>%s</option>', $value, in_array( $value, $this->data, true ) ? ' selected="true"' : '', $label ); } $output .= '</select>'; return $output; } } /** * @param $settings * @param $value * * @return string */ function vc_column_offset_form_field( $settings, $value ) { $column_offset = new Vc_Column_Offset( $settings, $value ); return $column_offset->render(); } /** * @param $column_offset * @param $width * * @return mixed|string */ function vc_column_offset_class_merge( $column_offset, $width ) { // Remove offset settings if if ( '1' === vc_settings()->get( 'not_responsive_css' ) ) { $column_offset = preg_replace( '/vc_col\-(lg|md|xs)[^\s]*/', '', $column_offset ); } if ( preg_match( '/vc_col\-sm\-\d+/', $column_offset ) ) { return $column_offset; } return $width . ( empty( $column_offset ) ? '' : ' ' . $column_offset ); } /** * */ function vc_load_column_offset_param() { vc_add_shortcode_param( 'column_offset', 'vc_column_offset_form_field' ); } add_action( 'vc_load_default_params', 'vc_load_column_offset_param' );