234 lines
7.0 KiB
PHP
234 lines
7.0 KiB
PHP
|
<?php
|
||
|
namespace Elementor;
|
||
|
|
||
|
if ( ! defined( 'ABSPATH' ) ) {
|
||
|
exit; // Exit if accessed directly.
|
||
|
}
|
||
|
|
||
|
class Group_Control_Flex_Container extends Group_Control_Base {
|
||
|
|
||
|
protected static $fields;
|
||
|
|
||
|
public static function get_type() {
|
||
|
return 'flex-container';
|
||
|
}
|
||
|
|
||
|
protected function init_fields() {
|
||
|
$start = is_rtl() ? 'right' : 'left';
|
||
|
$end = is_rtl() ? 'left' : 'right';
|
||
|
|
||
|
$fields = [];
|
||
|
|
||
|
$fields['items'] = [
|
||
|
'type' => Controls_Manager::HEADING,
|
||
|
'label' => esc_html__( 'Items', 'elementor' ),
|
||
|
'separator' => 'before',
|
||
|
];
|
||
|
|
||
|
$fields['direction'] = [
|
||
|
'label' => esc_html__( 'Direction', 'elementor' ),
|
||
|
'type' => Controls_Manager::CHOOSE,
|
||
|
'options' => [
|
||
|
'row' => [
|
||
|
'title' => esc_html__( 'Row - horizontal', 'elementor' ),
|
||
|
'icon' => 'eicon-arrow-' . $end,
|
||
|
],
|
||
|
'column' => [
|
||
|
'title' => esc_html__( 'Column - vertical', 'elementor' ),
|
||
|
'icon' => 'eicon-arrow-down',
|
||
|
],
|
||
|
'row-reverse' => [
|
||
|
'title' => esc_html__( 'Row - reversed', 'elementor' ),
|
||
|
'icon' => 'eicon-arrow-' . $start,
|
||
|
],
|
||
|
'column-reverse' => [
|
||
|
'title' => esc_html__( 'Column - reversed', 'elementor' ),
|
||
|
'icon' => 'eicon-arrow-up',
|
||
|
],
|
||
|
],
|
||
|
'default' => '',
|
||
|
// The `--container-widget-width` CSS variable is used for handling widgets that get an undefined width in column mode.
|
||
|
// The `--container-widget-flex-grow` CSS variable is used to give certain widgets a default `flex-grow: 1` value for the `flex row` combination.
|
||
|
'selectors_dictionary' => [
|
||
|
'row' => '--flex-direction: row; --container-widget-width: initial; --container-widget-height: 100%; --container-widget-flex-grow: 1; --container-widget-align-self: stretch;',
|
||
|
'column' => '--flex-direction: column; --container-widget-width: 100%; --container-widget-height: initial; --container-widget-flex-grow: 0; --container-widget-align-self: initial;',
|
||
|
'row-reverse' => '--flex-direction: row-reverse; --container-widget-width: initial; --container-widget-height: 100%; --container-widget-flex-grow: 1; --container-widget-align-self: stretch;',
|
||
|
'column-reverse' => '--flex-direction: column-reverse; --container-widget-width: 100%; --container-widget-height: initial; --container-widget-flex-grow: 0; --container-widget-align-self: initial;',
|
||
|
],
|
||
|
'selectors' => [
|
||
|
'{{SELECTOR}}' => '{{VALUE}};',
|
||
|
],
|
||
|
'responsive' => true,
|
||
|
];
|
||
|
|
||
|
// Only use the flex direction prefix class inside the editor.
|
||
|
$flex_direction_prefix_class = Plugin::$instance->editor->is_edit_mode() ? [ 'prefix_class' => 'e-con--' ] : [];
|
||
|
|
||
|
$fields['_is_row'] = array_merge( $flex_direction_prefix_class, [
|
||
|
'type' => Controls_Manager::HIDDEN,
|
||
|
'default' => 'row',
|
||
|
'condition' => [
|
||
|
'direction' => [
|
||
|
'row',
|
||
|
'row-reverse',
|
||
|
],
|
||
|
],
|
||
|
] );
|
||
|
|
||
|
$fields['_is_column'] = array_merge( $flex_direction_prefix_class, [
|
||
|
'type' => Controls_Manager::HIDDEN,
|
||
|
'default' => 'column',
|
||
|
'condition' => [
|
||
|
'direction' => [
|
||
|
'',
|
||
|
'column',
|
||
|
'column-reverse',
|
||
|
],
|
||
|
],
|
||
|
] );
|
||
|
|
||
|
$fields['justify_content'] = [
|
||
|
'label' => esc_html__( 'Justify Content', 'elementor' ),
|
||
|
'type' => Controls_Manager::CHOOSE,
|
||
|
'label_block' => true,
|
||
|
'default' => '',
|
||
|
'options' => [
|
||
|
'flex-start' => [
|
||
|
'title' => esc_html__( 'Start', 'elementor' ),
|
||
|
'icon' => 'eicon-flex eicon-justify-start-h',
|
||
|
],
|
||
|
'center' => [
|
||
|
'title' => esc_html__( 'Center', 'elementor' ),
|
||
|
'icon' => 'eicon-flex eicon-justify-center-h',
|
||
|
],
|
||
|
'flex-end' => [
|
||
|
'title' => esc_html__( 'End', 'elementor' ),
|
||
|
'icon' => 'eicon-flex eicon-justify-end-h',
|
||
|
],
|
||
|
'space-between' => [
|
||
|
'title' => esc_html__( 'Space Between', 'elementor' ),
|
||
|
'icon' => 'eicon-flex eicon-justify-space-between-h',
|
||
|
],
|
||
|
'space-around' => [
|
||
|
'title' => esc_html__( 'Space Around', 'elementor' ),
|
||
|
'icon' => 'eicon-flex eicon-justify-space-around-h',
|
||
|
],
|
||
|
'space-evenly' => [
|
||
|
'title' => esc_html__( 'Space Evenly', 'elementor' ),
|
||
|
'icon' => 'eicon-flex eicon-justify-space-evenly-h',
|
||
|
],
|
||
|
],
|
||
|
'selectors' => [
|
||
|
'{{SELECTOR}}' => '--justify-content: {{VALUE}};',
|
||
|
],
|
||
|
'responsive' => true,
|
||
|
];
|
||
|
|
||
|
$fields['align_items'] = [
|
||
|
'label' => esc_html__( 'Align Items', 'elementor' ),
|
||
|
'type' => Controls_Manager::CHOOSE,
|
||
|
'default' => '',
|
||
|
'options' => [
|
||
|
'flex-start' => [
|
||
|
'title' => esc_html__( 'Start', 'elementor' ),
|
||
|
'icon' => 'eicon-flex eicon-align-start-v',
|
||
|
],
|
||
|
'center' => [
|
||
|
'title' => esc_html__( 'Center', 'elementor' ),
|
||
|
'icon' => 'eicon-flex eicon-align-center-v',
|
||
|
],
|
||
|
'flex-end' => [
|
||
|
'title' => esc_html__( 'End', 'elementor' ),
|
||
|
'icon' => 'eicon-flex eicon-align-end-v',
|
||
|
],
|
||
|
'stretch' => [
|
||
|
'title' => esc_html__( 'Stretch', 'elementor' ),
|
||
|
'icon' => 'eicon-flex eicon-align-stretch-v',
|
||
|
],
|
||
|
],
|
||
|
'selectors' => [
|
||
|
'{{SELECTOR}}' => '--align-items: {{VALUE}}; --container-widget-width: calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );',
|
||
|
],
|
||
|
'responsive' => true,
|
||
|
];
|
||
|
|
||
|
$fields['gap'] = [
|
||
|
'label' => esc_html__( 'Gaps', 'elementor' ),
|
||
|
'type' => Controls_Manager::GAPS,
|
||
|
'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ],
|
||
|
'default' => [
|
||
|
'unit' => 'px',
|
||
|
],
|
||
|
'separator' => 'before',
|
||
|
'selectors' => [
|
||
|
'{{SELECTOR}}' => '--gap: {{ROW}}{{UNIT}} {{COLUMN}}{{UNIT}}',
|
||
|
],
|
||
|
'responsive' => true,
|
||
|
'conversion_map' => [
|
||
|
'old_key' => 'size',
|
||
|
'new_key' => 'column',
|
||
|
],
|
||
|
'upgrade_conversion_map' => [
|
||
|
'old_key' => 'size',
|
||
|
'new_keys' => [ 'column', 'row' ],
|
||
|
],
|
||
|
'validators' => [
|
||
|
'Number' => [
|
||
|
'min' => 0,
|
||
|
],
|
||
|
],
|
||
|
];
|
||
|
|
||
|
$fields['wrap'] = [
|
||
|
'label' => esc_html__( 'Wrap', 'elementor' ),
|
||
|
'type' => Controls_Manager::CHOOSE,
|
||
|
'options' => [
|
||
|
'nowrap' => [
|
||
|
'title' => esc_html__( 'No Wrap', 'elementor' ),
|
||
|
'icon' => 'eicon-flex eicon-nowrap',
|
||
|
],
|
||
|
'wrap' => [
|
||
|
'title' => esc_html__( 'Wrap', 'elementor' ),
|
||
|
'icon' => 'eicon-flex eicon-wrap',
|
||
|
],
|
||
|
],
|
||
|
'description' => esc_html__( 'Items within the container can stay in a single line (No wrap), or break into multiple lines (Wrap).', 'elementor' ),
|
||
|
'default' => '',
|
||
|
'selectors' => [
|
||
|
'{{SELECTOR}}' => '--flex-wrap: {{VALUE}};',
|
||
|
],
|
||
|
'responsive' => true,
|
||
|
];
|
||
|
|
||
|
$fields['align_content'] = [
|
||
|
'label' => esc_html__( 'Align Content', 'elementor' ),
|
||
|
'type' => Controls_Manager::SELECT,
|
||
|
'default' => '',
|
||
|
'options' => [
|
||
|
'' => esc_html__( 'Default', 'elementor' ),
|
||
|
'center' => esc_html__( 'Center', 'elementor' ),
|
||
|
'flex-start' => esc_html__( 'Start', 'elementor' ),
|
||
|
'flex-end' => esc_html__( 'End', 'elementor' ),
|
||
|
'space-between' => esc_html__( 'Space Between', 'elementor' ),
|
||
|
'space-around' => esc_html__( 'Space Around', 'elementor' ),
|
||
|
'space-evenly' => esc_html__( 'Space Evenly', 'elementor' ),
|
||
|
],
|
||
|
'selectors' => [
|
||
|
'{{SELECTOR}}' => '--align-content: {{VALUE}};',
|
||
|
],
|
||
|
'condition' => [
|
||
|
'wrap' => 'wrap',
|
||
|
],
|
||
|
'responsive' => true,
|
||
|
];
|
||
|
|
||
|
return $fields;
|
||
|
}
|
||
|
|
||
|
protected function get_default_options() {
|
||
|
return [
|
||
|
'popover' => false,
|
||
|
];
|
||
|
}
|
||
|
}
|