/wp-content/themes/plussed_old/library/admin/ReduxCore/inc/fields/group/field_group.php
PHP | 264 lines | 142 code | 49 blank | 73 comment | 20 complexity | f3bef011ca4f9438b4c96ec0589686f5 MD5 | raw file
- <?php
- /**
- * Redux Framework is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 2 of the License, or
- * any later version.
- *
- * Redux Framework is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with Redux Framework. If not, see <http://www.gnu.org/licenses/>.
- *
- * @package ReduxFramework
- * @subpackage Field_Info
- * @author Daniel J Griffiths (Ghost1227)
- * @author Dovy Paukstys
- * @author Abdullah Almesbahi
- * @author Jesús Mendoza (@vertigo7x)
- * @version 3.0.0
- */
- // Exit if accessed directly
- if (!defined('ABSPATH'))
- exit;
- // Don't duplicate me!
- if (!class_exists('ReduxFramework_group')) {
- /**
- * Main ReduxFramework_info class
- *
- * @since 1.0.0
- */
- class ReduxFramework_group extends ReduxFramework {
- /**
- * Field Constructor.
- *
- * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function
- *
- * @since 1.0.0
- * @access public
- * @return void
- */
- function __construct( $field = array(), $value ='', $parent ) {
-
- //parent::__construct( $parent->sections, $parent->args );
- $this->parent = $parent;
- $this->field = $field;
- $this->value = $value;
-
- }
- /**
- * Field Render Function.
- *
- * Takes the vars and outputs the HTML for the field in the settings
- *
- * @since 1.0.0
- * @access public
- * @return void
- */
- public function render() {
- if (empty($this->value) || !is_array($this->value)) {
- $this->value = array(
- array(
- 'slide_title' => __('New', 'redux-framework').' '.$this->field['groupname'],
- 'slide_sort' => '0',
- )
- );
- }
- $groups = $this->value;
- echo '<div class="redux-group">';
- echo '<input type="hidden" class="redux-dummy-slide-count" id="redux-dummy-' . $this->field['id'] . '-count" name="redux-dummy-' . $this->field['id'] . '-count" value="' . count($groups) . '" />';
- echo '<div id="redux-groups-accordion">';
- // Create dummy content for the adding new ones
- echo '<div class="redux-groups-accordion-group redux-dummy" style="display:none" id="redux-dummy-' . $this->field['id'] . '"><h3><span class="redux-groups-header">' . __("New ", "redux-framework") . $this->field['groupname'] . '</span></h3>';
- echo '<div>';//according content open
-
- echo '<table style="margin-top: 0;" class="redux-groups-accordion redux-group form-table no-border">';
- echo '<fieldset><input type="hidden" id="' . $this->field['id'] . '_slide-title" data-name="' . $this->parent->args['opt_name'] . '[' . $this->field['id'] . '][@][slide_title]" value="" class="regular-text slide-title" /></fieldset>';
- echo '<input type="hidden" class="slide-sort" data-name="' . $this->parent->args['opt_name'] . '[' . $this->field['id'] . '][@][slide_sort]" id="' . $this->field['id'] . '-slide_sort" value="" />';
- $field_is_title = true;
- foreach ($this->field['subfields'] as $field) {
- //we will enqueue all CSS/JS for sub fields if it wasn't enqueued
- $this->enqueue_dependencies($field['type']);
- echo '<tr><td>';
- if(isset($field['class']))
- $field['class'] .= " group";
- else
- $field['class'] = " group";
- if (!empty($field['title']))
- echo '<h4>' . $field['title'] . '</h4>';
- if (!empty($field['subtitle']))
- echo '<span class="description">' . $field['subtitle'] . '</span>';
- $value = empty($this->options[$field['id']][0]) ? "" : $this->options[$field['id']][0];
- ob_start();
- $this->_field_input($field, $value);
- $content = ob_get_contents();
- //adding sorting number to the name of each fields in group
- $name = $this->parent->args['opt_name'] . '[' . $field['id'] . ']';
- $content = str_replace($name,$this->parent->args['opt_name'] . '[' . $this->field['id'] . '][@]['.$field['id'].']', $content);
- // remove the name property. asigned by the controller, create new data-name property for js
- $content = str_replace('name', 'data-name', $content);
- if(($field['type'] === "text") && ($field_is_title)) {
- $content = str_replace('>', 'data-title="true" />', $content);
- $field_is_title = false;
- }
- //we should add $sort to id to fix problem with select field
- $content = str_replace(' id="'.$field['id'].'-select"', ' id="'.$field['id'].'-select-'.$sort.'"', $content);
-
- $_field = apply_filters('redux-support-group',$content, $field, 0);
- ob_end_clean();
- echo $_field;
-
- echo '</td></tr>';
- }
- echo '</table>';
- echo '<a href="javascript:void(0);" class="button deletion redux-groups-remove">' . __('Delete', 'redux-framework').' '. $this->field['groupname']. '</a>';
- echo '</div></div>';
- // Create real groups
- $x = 0;
- foreach ($groups as $group) {
- echo '<div class="redux-groups-accordion-group"><h3><span class="redux-groups-header">' . $group['slide_title'] . '</span></h3>';
- echo '<div>';//according content open
-
- echo '<table style="margin-top: 0;" class="redux-groups-accordion redux-group form-table no-border">';
-
- //echo '<h4>' . __('Group Title', 'redux-framework') . '</h4>';
- echo '<fieldset><input type="hidden" id="' . $this->field['id'] . '-slide_title_' . $x . '" name="' . $this->parent->args['opt_name'] . '[' . $this->field['id'] . '][' . $x . '][slide_title]" value="' . esc_attr($group['slide_title']) . '" class="regular-text slide-title" /></fieldset>';
- echo '<input type="hidden" class="slide-sort" name="' . $this->parent->args['opt_name'] . '[' . $this->field['id'] . '][' . $x . '][slide_sort]" id="' . $this->field['id'] . '-slide_sort_' . $x . '" value="' . $group['slide_sort'] . '" />';
-
- $field_is_title = true;
- foreach ($this->field['subfields'] as $field) {
- //we will enqueue all CSS/JS for sub fields if it wasn't enqueued
- $this->enqueue_dependencies($field['type']);
-
- echo '<tr><td>';
- if(isset($field['class']))
- $field['class'] .= " group";
- else
- $field['class'] = " group";
- if (!empty($field['title']))
- echo '<h4>' . $field['title'] . '</h4>';
- if (!empty($field['subtitle']))
- echo '<span class="description">' . $field['subtitle'] . '</span>';
- if (isset($group[$field['id']]) && !empty($group[$field['id']])) {
- $value = $group[$field['id']];
- }
-
- $value = empty($value) ? "" : $value;
- ob_start();
- $this->_field_input($field, $value);
- //if (isset($this->options[$field['id']]) && !empty($this->options[$field['id']]) && is_array($this->options[$field['id']])) {
- // $value = next($this->options[$field['id']]);
- //}
- $content = ob_get_contents();
- //adding sorting number to the name of each fields in group
- $name = $this->parent->args['opt_name'] . '[' . $field['id'] . ']';
- $content = str_replace($name, $this->parent->args['opt_name'] . '[' . $this->field['id'] . ']['.$x.']['.$field['id'].']', $content);
- //we should add $sort to id to fix problem with select field
- $content = str_replace(' id="'.$field['id'].'-select"', ' id="'.$field['id'].'-select-'.$sort.'"', $content);
- if(($field['type'] === "text") && ($field_is_title)) {
- $content = str_replace('>', 'data-title="true" />', $content);
- $field_is_title = false;
- }
-
- $_field = apply_filters('redux-support-group',$content, $field, $x);
- ob_end_clean();
- echo $_field;
-
- echo '</td></tr>';
- }
- echo '</table>';
- echo '<a href="javascript:void(0);" class="button deletion redux-groups-remove">' . __('Delete', 'redux-framework').' '.$this->field['groupname']. '</a>';
- echo '</div></div>';
- $x++;
- }
- echo '</div><a href="javascript:void(0);" class="button redux-groups-add button-primary" rel-id="' . $this->field['id'] . '-ul" rel-name="' . $this->parent->args['opt_name'] . '[' . $this->field['id'] . '][slide_title][]">' . __('Add', 'redux-framework') .' '.$this->field['groupname']. '</a><br/>';
- echo '</div>';
-
- }
- function support_multi($content, $field, $sort) {
- //convert name
- $name = $this->parent->args['opt_name'] . '[' . $field['id'] . ']';
- $content = str_replace($name, $name . '[' . $sort . ']', $content);
- //we should add $sort to id to fix problem with select field
- $content = str_replace(' id="'.$field['id'].'-select"', ' id="'.$field['id'].'-select-'.$sort.'"', $content);
- return $content;
- }
- /**
- * Enqueue Function.
- *
- * If this field requires any scripts, or css define this function and register/enqueue the scripts/css
- *
- * @since 1.0.0
- * @access public
- * @return void
- */
- public function enqueue() {
- wp_enqueue_script(
- 'redux-field-group-js',
- ReduxFramework::$_url . 'inc/fields/group/field_group.js',
- array('jquery', 'jquery-ui-core', 'jquery-ui-accordion', 'wp-color-picker'),
- time(),
- true
- );
- wp_enqueue_style(
- 'redux-field-group-css',
- ReduxFramework::$_url . 'inc/fields/group/field_group.css',
- time(),
- true
- );
- }
- public function enqueue_dependencies($field_type) {
- $field_class = 'ReduxFramework_' . $field_type;
- if (!class_exists($field_class)) {
- $class_file = apply_filters('redux-typeclass-load', ReduxFramework::$_dir . 'inc/fields/' . $field_type . '/field_' . $field_type . '.php', $field_class);
- if ($class_file) {
- /** @noinspection PhpIncludeInspection */
- require_once( $class_file );
- }
- }
- if (class_exists($field_class) && method_exists($field_class, 'enqueue')) {
- $enqueue = new $field_class('', '', $this);
- $enqueue->enqueue();
- }
- }
- }
- }