SILENT KILLERPanel

Current Path: > home > transcarter > > www > wp-content > themes > bridge > framework > lib


Operation   : Linux host59.registrar-servers.com 4.18.0-513.18.1.lve.2.el8.x86_64 #1 SMP Sat Mar 30 15:36:11 UTC 2024 x86_64
Software     : Apache
Server IP    : 198.54.126.42 | Your IP: 216.73.216.135
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: /home/transcarter//www/wp-content/themes/bridge/framework/lib

NameTypeSizeLast ModifiedActions
qode.icons Directory - -
google-fonts.php File 796718 bytes March 10 2023 20:42:10.
qode.framework.php File 11664 bytes March 10 2023 20:42:10.
qode.functions.php File 30520 bytes March 10 2023 20:42:10.
qode.layout.dashboard.php File 57365 bytes March 10 2023 20:42:10.
qode.layout.tax.php File 15796 bytes March 10 2023 20:42:10.
qode.layout.user.php File 5639 bytes March 10 2023 20:42:10.
qode.layout1.php File 52286 bytes March 10 2023 20:42:10.
qode.layout2.php File 53358 bytes March 10 2023 20:42:10.
qode.layout3.php File 95669 bytes March 10 2023 20:42:10.
qode.optionsapi.php File 37079 bytes March 10 2023 20:42:10.

Reading File: /home/transcarter//www/wp-content/themes/bridge/framework/lib/qode.optionsapi.php

<?php
if(!function_exists('bridge_qode_add_admin_page')) {
    /**
     * Generates admin page object and adds it to options
     * $attributes array can container:
     *      $slug - slug of the page with which it will be registered in admin, and which will be appended to admin URL
     *      $title - title of the page
     *      $icon - icon that will be added to admin page in options navigation
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeAdminPage
     */
    function bridge_qode_add_admin_page($attributes) {
        $slug = '';
        $title = '';
        $icon = '';

        extract($attributes);

        if(isset($slug) && !empty($title)) {
            $admin_page = new BridgeQodeAdminPage($slug, $title, $icon);
            bridge_qode_framework()->qodeOptions->addAdminPage($slug, $admin_page);

            return $admin_page;
        }

        return false;
    }
}

if(!function_exists('bridge_qode_add_admin_panel')) {
    /**
     * Generates panel object from given parameters
     * $attributes can container:
     *      $title - title of panel
     *      $name - name of panel with which it will be registered in admin page
     *      $hidden_property - name of option that hides panel
     *      $hidden_value - value of $hidden_property that hides panel
     *      $hidden_values - array of valus of $hidden_property that hides panel
     *      $page - slug of that page to which to add panel
     *
     * @param $attributes
     *
     * @return bool|BridgeQodePanel
     */
    function bridge_qode_add_admin_panel($attributes) {
        $title           = '';
        $name            = '';
        $hidden_property = '';
        $hidden_value    = '';
        $hidden_values   = array();
        $page            = '';

        extract($attributes);

        if(isset($page) && !empty($title) && !empty($name) && bridge_qode_framework()->qodeOptions->adminPageExists($page)) {
            $admin_page = bridge_qode_framework()->qodeOptions->getAdminPage($page);

            if(is_object($admin_page)) {
                $panel = new BridgeQodePanel($title, $name, $hidden_property, $hidden_value, $hidden_values);
                $admin_page->addChild($name, $panel);

                return $panel;
            }
        }

        return false;
    }
}

if(!function_exists('bridge_qode_add_admin_container')) {
    /**
     * Generates container object
     * $attributes can contain:
     *      $name - name of the container with which it will be added to parent element
     *      $parent - parent object to which to add container
     *      $hidden_property - name of option that hides container
     *      $hidden_value - value of $hidden_property that hides container
     *      $hidden_values - array of valus of $hidden_property that hides container
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeContainer
     */
    function bridge_qode_add_admin_container($attributes) {
        $name            = '';
        $parent          = '';
        $hidden_property = '';
        $hidden_value    = '';
        $hidden_values   = array();

        extract($attributes);

        if(!empty($name) && is_object($parent)) {
            $container = new BridgeQodeContainer($name, $hidden_property, $hidden_value, $hidden_values);
            $parent->addChild($name, $container);

            return $container;
        }

        return false;
    }
}

if(!function_exists('bridge_qode_add_admin_twitter_button')) {

    /**
     * Generates twitter button field
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeTwitterFramework
     */
    function bridge_qode_add_admin_twitter_button($attributes) {
        $name = '';
        $parent = '';

        extract($attributes);

        if(!empty($parent) && !empty($name)) {
            $field = new BridgeQodeTwitterFramework();

            if(is_object($parent)) {
                $parent->addChild($name, $field);
            }

            return $field;
        }

        return false;
    }
}

if(!function_exists('bridge_qode_add_admin_instagram_button')) {

    /**
     * Generates instagram button field
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeInstagramFramework
     */
    function bridge_qode_add_admin_instagram_button($attributes) {
        $name = '';
        $parent = '';

        extract($attributes);

        if(!empty($parent) && !empty($name)) {
            $field = new BridgeQodeInstagramFramework();

            if(is_object($parent)) {
                $parent->addChild($name, $field);
            }

            return $field;
        }

        return false;
    }
}

if(!function_exists('bridge_qode_add_admin_container_no_style')) {
    /**
     * Generates container object
     * $attributes can contain:
     *      $name - name of the container with which it will be added to parent element
     *      $parent - parent object to which to add container
     *      $hidden_property - name of option that hides container
     *      $hidden_value - value of $hidden_property that hides container
     *      $hidden_values - array of valus of $hidden_property that hides container
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeContainerNoStyle
     */
    function bridge_qode_add_admin_container_no_style($attributes) {
        $name            = '';
        $parent          = '';
        $hidden_property = '';
        $hidden_value    = '';
        $hidden_values   = array();

        extract($attributes);

        if(!empty($name) && is_object($parent)) {
            $container = new BridgeQodeContainerNoStyle($name, $hidden_property, $hidden_value, $hidden_values);
            $parent->addChild($name, $container);

            return $container;
        }

        return false;
    }
}

if(!function_exists('bridge_qode_add_admin_group')) {
    /**
     * Generates group object
     * $attributes can contain:
     *      $name - name of the group with which it will be added to parent element
     *      $title - title of group
     *      $description - description of group
     *      $parent - parent object to which to add group
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeGroup
     */
    function bridge_qode_add_admin_group($attributes) {
        $name = '';
        $title = '';
        $description = '';
        $parent = '';

        extract($attributes);

        if(!empty($name) && !empty($title) && is_object($parent)) {
            $group = new BridgeQodeGroup($title, $description);
            $parent->addChild($name, $group);

            return $group;
        }

        return false;
    }
}

if(!function_exists('bridge_qode_add_admin_row')) {
    /**
     * Generates row object
     * $attributes can contain:
     *      $name - name of the group with which it will be added to parent element
     *      $parent - parent object to which to add row
     *      $next - whether row has next row. Used to add bottom margin class
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeRow
     */
    function bridge_qode_add_admin_row($attributes) {
        $parent = '';
        $next   = false;
        $name   = '';

        extract($attributes);

        if(is_object($parent)) {
            $row = new BridgeQodeRow($next);
            $parent->addChild($name, $row);

            return $row;
        }

        return false;
    }
}

if(!function_exists('bridge_qode_add_admin_field')) {
    /**
     * Generates admin field object
     * $attributes can container:
     *      $type - type of the field to generate
     *      $name - name of the field. This will be name of the option in database
     *      $default_value
     *      $label - title of the option
     *      $description
     *      $options - assoc array of option. Used only for select and radiogroup field types
     *      $args - assoc array of additional parameters. Used for dependency
     *      $hidden_property - name of option that hides field
     *      $hidden_values - array of valus of $hidden_property that hides field
     *      $parent - parent object to which to add field
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeField
     */
    function bridge_qode_add_admin_field($attributes) {
        $type            = '';
        $name            = '';
        $default_value   = '';
        $label           = '';
        $description     = '';
        $options         = array();
        $args            = array();
        $hidden_property = '';
        $hidden_values   = array();
        $parent          = '';

        extract($attributes);

        if(!empty($parent) && !empty($type) && !empty($name)) {
            $field = new BridgeQodeField($type, $name, $default_value, $label, $description, $options, $args, $hidden_property, $hidden_values);

            if(is_object($parent)) {
                $parent->addChild($name, $field);

                return $field;
            }
        }

        return false;
    }
}

if(!function_exists('bridge_qode_add_admin_section_title')) {
    /**
     * Generates admin title field
     * $attributes can contain:
     *      $parent - parent object to which to add title
     *      $name - name of title with which to add it to the parent
     *      $title - title text
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeTitle
     */
    function bridge_qode_add_admin_section_title($attributes) {
        $parent = '';
        $name = '';
        $title = '';

        extract($attributes);

        if(is_object($parent) && !empty($title) && !empty($name)) {
            $section_title = new BridgeQodeTitle($name, $title);
            $parent->addChild($name, $section_title);

            return $section_title;
        }

        return false;
    }
}

if(!function_exists('bridge_qode_add_admin_notice')) {
    /**
     * Generates QodeNotice object from given parameters
     * $attributes array can contain:
     *      $title - title of notice object
     *      $description - description of notice object
     *      $notice - text of notice to display
     *      $hidden_property - name of option that hides notice
     *      $hidden_value - value of $hidden_property that hides notice
     *      $hidden_values - assoc array of values of $hidden_property that hides notice
     *      $name - unique name of notice with which it will be added to it's parent
     *      $parent - object to which to add notice object using addChild method
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeNotice
     */
    function bridge_qode_add_admin_notice($attributes) {
        $title           = '';
        $description     = '';
        $notice          = '';
        $hidden_property = '';
        $hidden_value    = '';
        $hidden_values   = array();
        $parent          = '';
        $name            = '';

        extract($attributes);

        if(is_object($parent) && !empty($title) && !empty($notice) && !empty($name)) {
            $notice_object = new BridgeQodeNotice($title, $description, $notice, $hidden_property, $hidden_value, $hidden_values);
            $parent->addChild($name, $notice_object);

            return $notice_object;
        }

        return false;
    }
}

if(!function_exists('bridge_qode_framework')) {
    /**
     * Function that returns instance of QodeFramework class
     *
     * @return BridgeQodeFramework
     */
    function bridge_qode_framework() {
        return BridgeQodeFramework::get_instance();
    }
}

if(!function_exists('bridge_qode_options')) {
    /**
     * Returns instance of QodeOptions class
     *
     * @return BridgeQodeOptions
     */
    function bridge_qode_options() {
        return bridge_qode_framework()->qodeOptions;
    }
}
if(!function_exists('bridge_qode_meta_boxes')) {
	/**
	 * Returns instance of QodeMetaBoxes class
	 *
	 * @return BridgeQodeMetaBoxes
	 */
	function bridge_qode_meta_boxes() {
		return bridge_qode_framework()->qodeMetaBoxes;
	}
}
/**
 * Meta boxes functions
 */
if(!function_exists('bridge_qode_create_meta_box')) {
    /**
     * Adds new meta box
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeMetaBox
     */
    function bridge_qode_create_meta_box($attributes) {
        $scope = array();
        $title = '';
        $hidden_property = '';
        $hidden_values = array();
        $name = '';

        extract($attributes);

        if(!empty($scope) && $title !== '' && $name !== '') {
            $meta_box_obj = new BridgeQodeMetaBox($scope, $title, $hidden_property, $hidden_values, $name);
            bridge_qode_framework()->qodeMetaBoxes->addMetaBox($name, $meta_box_obj);

            return $meta_box_obj;
        }

        return false;
    }
}

if(!function_exists('bridge_qode_create_meta_box_field')) {
    /**
     * Generates meta box field object
     * $attributes can contain:
     *      $type - type of the field to generate
     *      $name - name of the field. This will be name of the option in database
     *      $default_value
     *      $label - title of the option
     *      $description
     *      $options - assoc array of option. Used only for select and radiogroup field types
     *      $args - assoc array of additional parameters. Used for dependency
     *      $hidden_property - name of option that hides field
     *      $hidden_values - array of valus of $hidden_property that hides field
     *      $parent - parent object to which to add field
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeField
     */
    function bridge_qode_create_meta_box_field($attributes) {
        $type            = '';
        $name            = '';
        $default_value   = '';
        $label           = '';
        $description     = '';
        $options         = array();
        $args            = array();
        $hidden_property = '';
        $hidden_values   = array();
        $parent          = '';

        extract($attributes);

        if(!empty($parent) && !empty($type) && !empty($name)) {
            $field = new BridgeQodeMetaField($type, $name, $default_value, $label, $description, $options, $args, $hidden_property, $hidden_values);

            if(is_object($parent)) {
                $parent->addChild($name, $field);

                return $field;
            }
        }

        return false;
    }
}

if(!function_exists('bridge_qode_add_repeater_field')) {
	/**
	 * Generates meta box field object
	 * $attributes can contain:
	 *      $name - name of the field. This will be name of the option in database
	 *      $label - title of the option
	 *      $description
	 *      $field_type - type of the field that will be rendered and repeated
	 *      $parent - parent object to which to add field
	 *
	 * @param $attributes
	 *
	 * @return bool|RepeaterField
	 */
	function bridge_qode_add_repeater_field($attributes) {
		$name               = '';
		$label              = '';
		$description        = '';
		$fields             = array();
		$parent             = '';
		$button_text        = '';
		$field_domain       = 'meta';

		extract($attributes);

		if(!empty($parent) && !empty($name)) {
			$field = new BridgeQodeRepeater($fields, $name, $label, $description, $button_text, $field_domain);
			if(is_object($parent)) {

				$parent->addChild($name, $field);
				return $field;
			}
		}

		return false;
	}
}

/**
 * Taxonomy fields function
 */
if(!function_exists('bridge_qode_add_taxonomy_fields')) {
	/**
	 * Adds new meta box
	 *
	 * @param $attributes
	 *
	 * @return bool|BridgeQodeMetaBox
	 */
	function bridge_qode_add_taxonomy_fields($attributes) {
		$scope = array();
		$name = '';

		extract($attributes);

		if(!empty($scope)) {
			$tax_obj = new BridgeQodeTaxonomyOption($scope);
			bridge_qode_framework()->qodeTaxonomyOptions->addTaxonomyOptions($name, $tax_obj);

			return $tax_obj;
		}

		return false;
	}
}


if(!function_exists('bridge_qode_add_taxonomy_field')) {
	/**
	 * Generates meta box field object
	 * $attributes can contain:
	 *      $type - type of the field to generate
	 *      $name - name of the field. This will be name of the option in database
	 *      $label - title of the option
	 *      $description
	 *      $options - assoc array of option. Used only for select and radiogroup field types
	 *      $args - assoc array of additional parameters. Used for dependency
	 *      $parent - parent object to which to add field
	 *
	 * @param $attributes
	 *
	 * @return bool|RepeaterField
	 */
	function bridge_qode_add_taxonomy_field($attributes) {
		$type            = '';
		$name            = '';
		$label           = '';
		$description     = '';
		$options         = array();
		$args            = array();
		$parent          = '';

		extract($attributes);

		if(!empty($parent) && !empty($name)) {
			$field = new BridgeQodeTaxonomyField($type,$name,$label,$description,$options,$args);
			if(is_object($parent)) {
				$parent->addChild($name, $field);
				return $field;
			}
		}

		return false;
	}
}

if(!function_exists('bridge_qode_add_options_framework')) {
    /**
     * Generates meta box field object
     * $attributes can contain:
     *      $type - type of the field to generate
     *      $name - name of the field. This will be name of the option in database
     *      $default_value
     *      $label - title of the option
     *      $description
     *      $options - assoc array of option. Used only for select and radiogroup field types
     *      $args - assoc array of additional parameters. Used for dependency
     *      $hidden_property - name of option that hides field
     *      $hidden_values - array of valus of $hidden_property that hides field
     *      $parent - parent object to which to add field
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeField
     */
    function bridge_qode_add_options_framework($attributes) {
        $name            = '';
        $label           = '';
        $description     = '';
        $parent          = '';

        extract($attributes);

        if(!empty($parent) && !empty($name)) {
            $framework = new BridgeQodeOptionsFramework($label, $description);

            if(is_object($parent)) {
                $parent->addChild($name, $framework);

                return $framework;
            }
        }

        return false;
    }
}

if(!function_exists('bridge_qode_add_multiple_images_field')) {
    /**
     * Generates meta box field object
     * $attributes can contain:
     *      $name - name of the field. This will be name of the option in database
     *      $label - title of the option
     *      $description
     *      $parent - parent object to which to add field
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeField
     */
    function bridge_qode_add_multiple_images_field($attributes) {
        $name            = '';
        $label           = '';
        $description     = '';
        $parent          = '';

        extract($attributes);

        if(!empty($parent) && !empty($name)) {
            $field = new BridgeQodeMultipleImages($name,$label,$description);

            if(is_object($parent)) {
                $parent->addChild($name, $field);

                return $field;
            }
        }

        return false;
    }
}

if(!function_exists('bridge_qode_is_font_option_valid')) {
    /**
     * Checks if font family option is valid (different that -1)
     *
     * @param $option_name
     *
     * @return bool
     */
    function bridge_qode_is_font_option_valid($option_name) {
        return $option_name !== '-1' &&  $option_name !== '';
    }
}

if(!function_exists('bridge_qode_get_font_option_val')) {
    /**
     * Returns font option value without + so it can be used in css
     *
     * @param $option_val
     *
     * @return mixed
     */
    function bridge_qode_get_font_option_val($option_val) {
        $option_val = str_replace('+', ' ', $option_val);

        return $option_val;
    }
}

if ( ! function_exists('bridge_qode_get_yes_no_select_array') ) {
	/**
	 * Returns array of yes no
	 * @return array
	 */
	function bridge_qode_get_yes_no_select_array($enable_default = true, $set_yes_to_be_first = false ) {
		$select_options = array();

		if ( $enable_default ) {
			$select_options[''] = esc_html__( 'Default', 'bridge' );
		}

		if ( $set_yes_to_be_first ) {
			$select_options['yes'] = esc_html__( 'Yes', 'bridge' );
			$select_options['no']  = esc_html__( 'No', 'bridge' );
		} else {
			$select_options['no']  = esc_html__( 'No', 'bridge' );
			$select_options['yes'] = esc_html__( 'Yes', 'bridge' );
		}

		return $select_options;
	}
}

if ( ! function_exists('bridge_qode_get_query_order_by_array') ) {
	/**
	 * Returns array of query order by
	 *
	 * @param bool $first_empty whether to add empty first member
	 *
	 * @return array
	 */
	function bridge_qode_get_query_order_by_array($first_empty = false ) {
		$orderBy = array();

		if ( $first_empty ) {
			$orderBy[''] = esc_html__( 'Default', 'bridge' );
		}

		$orderBy['date']       = esc_html__( 'Date', 'bridge' );
		$orderBy['id']         = esc_html__( 'ID', 'bridge' );
		$orderBy['menu_order'] = esc_html__( 'Menu Order', 'bridge' );
		$orderBy['name']       = esc_html__( 'Post Name', 'bridge' );
		$orderBy['rand']       = esc_html__( 'Random', 'bridge' );
		$orderBy['title']      = esc_html__( 'Title', 'bridge' );

		return $orderBy;
	}
}

if ( ! function_exists('bridge_qode_get_query_order_array') ) {
	/**
	 * Returns array of query order
	 *
	 * @param bool $first_empty whether to add empty first member
	 *
	 * @return array
	 */
	function bridge_qode_get_query_order_array($first_empty = false ) {
		$order = array();

		if ( $first_empty ) {
			$order[''] = esc_html__( 'Default', 'bridge' );
		}

		$order['ASC']  = esc_html__( 'ASC', 'bridge' );
		$order['DESC'] = esc_html__( 'DESC', 'bridge' );

		return $order;
	}
}
if ( ! function_exists('bridge_qode_get_space_between_items_array') ) {
	/**
	 * Returns array of space between items
	 *
	 * @param bool $first_empty whether to add empty first member
	 * @param bool $enable_large whether to add huge member
	 * @param bool $enable_huge whether to add large member
	 *
	 * @return array
	 */
	function bridge_qode_get_space_between_items_array($first_empty = false, $enable_medium = true, $enable_large = true, $enable_huge = false ) {
		$spaceBetweenItems = array();

		if ( $first_empty ) {
			$spaceBetweenItems[''] = esc_html__( 'Default', 'bridge' );
		}

		if ( $enable_huge ) {
			$spaceBetweenItems['huge']   = esc_html__( 'Huge', 'bridge' );
		}

		if ( $enable_large ) {
			$spaceBetweenItems['large']  = esc_html__( 'Large', 'bridge' );
		}

		if ( $enable_medium ) {
			$spaceBetweenItems['medium']  = esc_html__( 'Medium', 'bridge' );
		}

		$spaceBetweenItems['normal'] = esc_html__( 'Normal', 'bridge' );
		$spaceBetweenItems['small']  = esc_html__( 'Small', 'bridge' );
		$spaceBetweenItems['tiny']   = esc_html__( 'Tiny', 'bridge' );
		$spaceBetweenItems['no']     = esc_html__( 'No', 'bridge' );

		return $spaceBetweenItems;
	}
}
if ( ! function_exists('bridge_qode_get_link_target_array') ) {
	/**
	 * Returns array of link target
	 *
	 * @param bool $first_empty whether to add empty first member
	 *
	 * @return array
	 */
	function bridge_qode_get_link_target_array($first_empty = false ) {
		$target_array = array();

		if ( $first_empty ) {
			$target_array[''] = esc_html__( 'Default', 'bridge' );
		}

		$target_array['_self']      = esc_html__( 'Same Window', 'bridge' );
		$target_array['_blank']     = esc_html__( 'New Window', 'bridge' );
		$target_array['_parent']    = esc_html__( 'Parent', 'bridge' );

		return $target_array;
	}
}

if ( ! function_exists('bridge_qode_get_title_tag') ) {
	/**
	 * Returns array of title tags
	 *
	 * @param bool $first_empty
	 * @param array $additional_elements
	 *
	 * @return array
	 */
	function bridge_qode_get_title_tag($first_empty = false, $additional_elements = array() ) {
		$title_tag = array();

		if ( $first_empty ) {
			$title_tag[''] = esc_html__( 'Default', 'bridge' );
		}

		$title_tag['h1'] = 'h1';
		$title_tag['h2'] = 'h2';
		$title_tag['h3'] = 'h3';
		$title_tag['h4'] = 'h4';
		$title_tag['h5'] = 'h5';
		$title_tag['h6'] = 'h6';
		$title_tag['p']	 = 'p';

		if ( ! empty( $additional_elements ) ) {
			$title_tag = array_merge( $title_tag, $additional_elements );
		}

		return $title_tag;
	}
}

if ( ! function_exists('bridge_qode_get_font_weight_array') ) {
	/**
	 * Returns array of font weights
	 *
	 * @param bool $first_empty whether to add empty first member
	 *
	 * @return array
	 */
	function bridge_qode_get_font_weight_array($first_empty = false ) {
		$font_weights = array();

		if ( $first_empty ) {
			$font_weights[''] = esc_html__( 'Default', 'bridge' );
		}

		$font_weights['100'] = esc_html__( '100 Thin', 'bridge' );
		$font_weights['200'] = esc_html__( '200 Thin-Light', 'bridge' );
		$font_weights['300'] = esc_html__( '300 Light', 'bridge' );
		$font_weights['400'] = esc_html__( '400 Normal', 'bridge' );
		$font_weights['500'] = esc_html__( '500 Medium', 'bridge' );
		$font_weights['600'] = esc_html__( '600 Semi-Bold', 'bridge' );
		$font_weights['700'] = esc_html__( '700 Bold', 'bridge' );
		$font_weights['800'] = esc_html__( '800 Extra-Bold', 'bridge' );
		$font_weights['900'] = esc_html__( '900 Ultra-Bold', 'bridge' );

		return $font_weights;
	}
}

if ( ! function_exists('bridge_qode_get_font_style_array') ) {
	/**
	 * Returns array of font styles
	 *
	 * @param bool $first_empty
	 *
	 * @return array
	 */
	function bridge_qode_get_font_style_array($first_empty = false ) {
		$font_styles = array();

		if ( $first_empty ) {
			$font_styles[''] = esc_html__( 'Default', 'bridge' );
		}

		$font_styles['normal']  = esc_html__( 'Normal', 'bridge' );
		$font_styles['italic']  = esc_html__( 'Italic', 'bridge' );
		$font_styles['oblique'] = esc_html__( 'Oblique', 'bridge' );
		$font_styles['initial'] = esc_html__( 'Initial', 'bridge' );
		$font_styles['inherit'] = esc_html__( 'Inherit', 'bridge' );

		return $font_styles;
	}
}

if ( ! function_exists('bridge_qode_get_text_transform_array') ) {
	/**
	 * Returns array of text transforms
	 *
	 * @param bool $first_empty
	 *
	 * @return array
	 */
	function bridge_qode_get_text_transform_array($first_empty = false ) {
		$text_transforms = array();

		if ( $first_empty ) {
			$text_transforms[''] = esc_html__( 'Default', 'bridge' );
		}

		$text_transforms['none']       = esc_html__( 'None', 'bridge' );
		$text_transforms['capitalize'] = esc_html__( 'Capitalize', 'bridge' );
		$text_transforms['uppercase']  = esc_html__( 'Uppercase', 'bridge' );
		$text_transforms['lowercase']  = esc_html__( 'Lowercase', 'bridge' );
		$text_transforms['initial']    = esc_html__( 'Initial', 'bridge' );
		$text_transforms['inherit']    = esc_html__( 'Inherit', 'bridge' );

		return $text_transforms;
	}
}

if ( ! function_exists('bridge_qode_get_text_decorations') ) {
	/**
	 * Returns array of text transforms
	 *
	 * @param bool $first_empty
	 *
	 * @return array
	 */
	function bridge_qode_get_text_decorations($first_empty = false ) {
		$text_decorations = array();

		if ( $first_empty ) {
			$text_decorations[''] = esc_html__( 'Default', 'bridge' );
		}

		$text_decorations['none']         = esc_html__( 'None', 'bridge' );
		$text_decorations['underline']    = esc_html__( 'Underline', 'bridge' );
		$text_decorations['overline']     = esc_html__( 'Overline', 'bridge' );
		$text_decorations['line-through'] = esc_html__( 'Line-Through', 'bridge' );
		$text_decorations['initial']      = esc_html__( 'Initial', 'bridge' );
		$text_decorations['inherit']      = esc_html__( 'Inherit', 'bridge' );

		return $text_decorations;
	}
}











/**
 * User fields function
 */
if ( ! function_exists( 'bridge_qode_add_user_fields' ) ) {
    /**
     * Adds new meta box
     *
     * @param $attributes
     *
     * @return bool|QodeMetaBox
     */
    function bridge_qode_add_user_fields( $attributes ) {
        $scope = array();
        $name  = '';

        extract( $attributes );

        if ( ! empty( $scope ) ) {
            $user_obj = new BridgeQodeUserOption( $scope );
            bridge_qode_framework()->qodefUserOptions->addUserOptions( $name, $user_obj );

            return $user_obj;
        }

        return false;
    }
}

if ( ! function_exists( 'bridge_qode_add_user_field' ) ) {
    /**
     * Generates meta box field object
     * $attributes can contain:
     *      $type - type of the field to generate
     *      $name - name of the field. This will be name of the option in database
     *      $label - title of the option
     *      $description
     *      $options - assoc array of option. Used only for select and radiogroup field types
     *      $args - assoc array of additional parameters. Used for dependency
     *      $parent - parent object to which to add field
     *
     * @param $attributes
     *
     * @return bool|RepeaterField
     */
    function bridge_qode_add_user_field( $attributes ) {
        $type        = '';
        $name        = '';
        $label       = '';
        $description = '';
        $options     = array();
        $args        = array();
        $parent      = '';

        extract( $attributes );

        if ( ! empty( $parent ) && ! empty( $name ) ) {
            $field = new BridgeQodeUserField( $type, $name, $label, $description, $options, $args );
            if ( is_object( $parent ) ) {
                $parent->addChild( $name, $field );

                return $field;
            }
        }

        return false;
    }
}

if ( ! function_exists( 'bridge_qode_add_user_group' ) ) {
    /**
     * Generates group object
     * $attributes can contain:
     *      $name - name of the group with which it will be added to parent element
     *      $title - title of group
     *      $description - description of group
     *      $parent - parent object to which to add group
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeUserGroup
     */
    function bridge_qode_add_user_group( $attributes ) {
        $name        = '';
        $title       = '';
        $description = '';
        $parent      = '';

        extract( $attributes );

        if ( ! empty( $name ) && ! empty( $title ) && is_object( $parent ) ) {
            $group = new BridgeQodeUserGroup( $title, $description );
            $parent->addChild( $name, $group );

            return $group;
        }

        return false;
    }
}

/**
 * Dashboard fields function
 */

if ( ! function_exists( 'bridge_qode_add_dashboard_fields' ) ) {
    /**
     * Adds new meta box
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeDashboardOption
     */
    function bridge_qode_add_dashboard_fields( $attributes ) {
        $name = '';

        extract( $attributes );

        if ( $name !== '') {
            $dash_obj = new BridgeQodeDashboardOption();
            bridge_qode_framework()->qodeDashboardOptions->addDashboardOptions( $name, $dash_obj );

            return $dash_obj;
        }

        return false;
    }
}

if ( ! function_exists( 'bridge_qode_add_dashboard_form' ) ) {
    /**
     * Generates form object
     * $attributes can contain:
     *      $name - name of the form with which it will be added to parent element
     *      $parent - parent object to which to add form
     *      $form_id - id of form generated
     *      $form_method - method for form generated
     *      $form_nonce - nonce for form generated
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeDashboardForm
     */
    function bridge_qode_add_dashboard_form( $attributes ) {
        $name				= '';
        $form_id			= '';
        $form_method		= 'post';
        $form_action		= '';
        $form_nonce_action	= '';
        $form_nonce_name	= '';
        $button_label		= esc_html__('SUMBIT','bridge');
        $button_args		= array();
        $parent				= '';

        extract( $attributes );

        if ( ! empty( $name ) && is_object( $parent ) && $form_id !== '') {
            $container = new BridgeQodeDashboardForm( $name, $form_id, $form_method, $form_action, $form_nonce_action, $form_nonce_name, $button_label, $button_args);
            $parent->addChild( $name, $container );

            return $container;
        }

        return false;
    }
}

if ( ! function_exists( 'bridge_qode_add_dashboard_group' ) ) {
    /**
     * Generates form object
     * $attributes can contain:
     *      $name - name of the form with which it will be added to parent element
     *      $parent - parent object to which to add form
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeDashboardGroup
     */
    function bridge_qode_add_dashboard_group( $attributes ) {
        $name		 = '';
        $title 		 = '';
        $description = '';
        $parent		 = '';

        extract( $attributes );

        if ( ! empty( $name ) && is_object( $parent ) ) {
            $container = new BridgeQodeDashboardGroup( $name, $title, $description );
            $parent->addChild( $name, $container );

            return $container;
        }

        return false;
    }
}

if ( ! function_exists( 'bridge_qode_add_dashboard_section_title' ) ) {
    /**
     * Generates dashboard title field
     * $attributes can contain:
     *      $parent - parent object to which to add title
     *      $name - name of title with which to add it to the parent
     *      $title - title text
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeDashboardTitle
     */
    function bridge_qode_add_dashboard_section_title( $attributes ) {
        $parent = '';
        $name   = '';
        $title  = '';
        $args   = array();

        extract( $attributes );

        if ( is_object( $parent ) && ! empty( $title ) && ! empty( $name ) ) {
            $section_title = new BridgeQodeDashboardTitle( $name, $title, $args );
            $parent->addChild( $name, $section_title );

            return $section_title;
        }

        return false;
    }
}

if ( ! function_exists( 'bridge_qode_add_dashboard_repeater_field' ) ) {
    /**
     * Generates meta box field object
     * $attributes can contain:
     *      $name - name of the field. This will be name of the option in database
     *      $label - title of the option
     *      $description
     *      $field_type - type of the field that will be rendered and repeated
     *      $parent - parent object to which to add field
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeDashboardRepeater
     */
    function bridge_qode_add_dashboard_repeater_field( $attributes ) {
        $name        = '';
        $label       = '';
        $description = '';
        $fields      = array();
        $parent      = '';
        $button_text = '';
        $table_layout = false;
        $value = array();

        extract( $attributes );

        if ( ! empty( $parent ) && ! empty( $name ) ) {
            $field = new BridgeQodeDashboardRepeater( $fields, $name, $label, $description, $button_text, $table_layout, $value);

            if ( is_object( $parent ) ) {
                $parent->addChild( $name, $field );

                return $field;
            }
        }

        return false;
    }
}

if ( ! function_exists( 'bridge_qode_add_dashboard_field' ) ) {
    /**
     * Generates dashboard field object
     * $attributes can contain:
     *      $type - type of the field to generate
     *      $name - name of the field. This will be name of the option in database
     *      $label - title of the option
     *      $description
     *      $options - assoc array of option. Used only for select and radiogroup field types
     *      $args - assoc array of additional parameters. Used for dependency
     *      $parent - parent object to which to add field
     *      $hidden_property - name of option that hides field
     *      $hidden_values - array of valus of $hidden_property that hides field
     *
     * @param $attributes
     *
     * @return bool|BridgeQodeDashboardField
     */
    function bridge_qode_add_dashboard_field( $attributes ) {
        $type        = '';
        $name        = '';
        $label       = '';
        $description = '';
        $options     = array();
        $args        = array();
        $value       = '';
        $parent      = '';
        $repeat      = array();

        extract( $attributes );

        if ( ! empty( $parent ) && ! empty( $name ) ) {
            $field = new BridgeQodeDashboardField( $type, $name, $label, $description, $options, $args, $value, $repeat);
            if ( is_object( $parent ) ) {
                $parent->addChild( $name, $field );

                return $field;
            }
        }

        return false;
    }
}

SILENT KILLER Tool