Server IP : 192.64.112.168 / Your IP : 52.15.57.54 Web Server : Apache System : Linux nc-ph-2300-85.bluforrest.com 4.18.0-513.9.1.el8_9.x86_64 #1 SMP Sat Dec 2 05:23:44 EST 2023 x86_64 User : expressoneac ( 1128) PHP Version : 8.0.30 Disable Function : exec,passthru,shell_exec,system MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /home/expressoneac/www/wp-content/plugins/elementor-pro/modules/woocommerce/widgets/ |
Upload File : |
<?php namespace ElementorPro\Modules\Woocommerce\Widgets; use Elementor\Controls_Manager; use Elementor\Controls_Stack; use Elementor\Core\Breakpoints\Manager as Breakpoints_Manager; use ElementorPro\Modules\Woocommerce\Classes\Products_Renderer; use ElementorPro\Modules\Woocommerce\Traits\Product_Id_Trait; if ( ! defined( 'ABSPATH' ) ) { exit; // Exit if accessed directly. } abstract class Base_Widget extends \ElementorPro\Base\Base_Widget { use Product_Id_Trait; protected $gettext_modifications; public function get_categories() { return [ 'woocommerce-elements-single' ]; } protected function get_devices_default_args() { $devices_required = []; // Make sure device settings can inherit from larger screen sizes' breakpoint settings. foreach ( Breakpoints_Manager::get_default_config() as $breakpoint_name => $breakpoint_config ) { $devices_required[ $breakpoint_name ] = [ 'required' => false, ]; } return $devices_required; } protected function add_columns_responsive_control() { $this->add_responsive_control( 'columns', [ 'label' => esc_html__( 'Columns', 'elementor-pro' ), 'type' => Controls_Manager::NUMBER, 'prefix_class' => 'elementor-grid%s-', 'min' => 1, 'max' => 12, 'default' => Products_Renderer::DEFAULT_COLUMNS_AND_ROWS, 'tablet_default' => '3', 'mobile_default' => '2', 'required' => true, 'device_args' => $this->get_devices_default_args(), 'min_affected_device' => [ Controls_Stack::RESPONSIVE_DESKTOP => Controls_Stack::RESPONSIVE_TABLET, Controls_Stack::RESPONSIVE_TABLET => Controls_Stack::RESPONSIVE_TABLET, ], ] ); } /** * Is WooCommerce Feature Active. * * Checks whether a specific WooCommerce feature is active. These checks can sometimes look at multiple WooCommerce * settings at once so this simplifies and centralizes the checking. * * @since 3.5.0 * * @param string $feature * @return bool */ protected function is_wc_feature_active( $feature ) { switch ( $feature ) { case 'checkout_login_reminder': return 'yes' === get_option( 'woocommerce_enable_checkout_login_reminder' ); case 'shipping': if ( class_exists( 'WC_Shipping_Zones' ) ) { $all_zones = \WC_Shipping_Zones::get_zones(); if ( count( $all_zones ) > 0 ) { return true; } } break; case 'coupons': return function_exists( 'wc_coupons_enabled' ) && wc_coupons_enabled(); case 'signup_and_login_from_checkout': return 'yes' === get_option( 'woocommerce_enable_signup_and_login_from_checkout' ); case 'ship_to_billing_address_only': return wc_ship_to_billing_address_only(); } return false; } /** * Get Custom Border Type Options * * Return a set of border options to be used in different WooCommerce widgets. * * This will be used in cases where the Group Border Control could not be used. * * @since 3.5.0 * * @return array */ public static function get_custom_border_type_options() { return [ 'none' => esc_html__( 'None', 'elementor-pro' ), 'solid' => esc_html__( 'Solid', 'elementor-pro' ), 'double' => esc_html__( 'Double', 'elementor-pro' ), 'dotted' => esc_html__( 'Dotted', 'elementor-pro' ), 'dashed' => esc_html__( 'Dashed', 'elementor-pro' ), 'groove' => esc_html__( 'Groove', 'elementor-pro' ), ]; } /** * Init Gettext Modifications * * Should be overridden by a method in the Widget class. * * @since 3.5.0 */ protected function init_gettext_modifications() { $this->gettext_modifications = []; } /** * Filter Gettext. * * Filter runs when text is output to the page using the translation functions (`_e()`, `__()`, etc.) * used to apply text changes from the widget settings. * * This allows us to make text changes without having to ovveride WooCommerce templates, which would * lead to dev tax to keep all the templates up to date with each future WC release. * * @since 3.5.0 * * @param string $translation * @param string $text * @param string $domain * @return string */ public function filter_gettext( $translation, $text, $domain ) { if ( 'woocommerce' !== $domain && 'elementor-pro' !== $domain ) { return $translation; } if ( ! isset( $this->gettext_modifications ) ) { $this->init_gettext_modifications(); } return array_key_exists( $text, $this->gettext_modifications ) ? $this->gettext_modifications[ $text ] : $translation; } }