declare (strict_types=1); namespace ElementorDeps\DI; use ElementorDeps\DI\Definition\ArrayDefinitionExtension; use ElementorDeps\DI\Definition\EnvironmentVariableDefinition; use ElementorDeps\DI\Definition\Helper\AutowireDefinitionHelper; use ElementorDeps\DI\Definition\Helper\CreateDefinitionHelper; use ElementorDeps\DI\Definition\Helper\FactoryDefinitionHelper; use ElementorDeps\DI\Definition\Reference; use ElementorDeps\DI\Definition\StringDefinition; use ElementorDeps\DI\Definition\ValueDefinition; if (!\function_exists('ElementorDeps\\DI\\value')) { /** * Helper for defining a value. * * @param mixed $value */ function value($value) : ValueDefinition { return new ValueDefinition($value); } } if (!\function_exists('ElementorDeps\\DI\\create')) { /** * Helper for defining an object. * * @param string|null $className Class name of the object. * If null, the name of the entry (in the container) will be used as class name. */ function create(string $className = null) : CreateDefinitionHelper { return new CreateDefinitionHelper($className); } } if (!\function_exists('ElementorDeps\\DI\\autowire')) { /** * Helper for autowiring an object. * * @param string|null $className Class name of the object. * If null, the name of the entry (in the container) will be used as class name. */ function autowire(string $className = null) : AutowireDefinitionHelper { return new AutowireDefinitionHelper($className); } } if (!\function_exists('ElementorDeps\\DI\\factory')) { /** * Helper for defining a container entry using a factory function/callable. * * @param callable $factory The factory is a callable that takes the container as parameter * and returns the value to register in the container. */ function factory($factory) : FactoryDefinitionHelper { return new FactoryDefinitionHelper($factory); } } if (!\function_exists('ElementorDeps\\DI\\decorate')) { /** * Decorate the previous definition using a callable. * * Example: * * 'foo' => decorate(function ($foo, $container) { * return new CachedFoo($foo, $container->get('cache')); * }) * * @param callable $callable The callable takes the decorated object as first parameter and * the container as second. */ function decorate($callable) : FactoryDefinitionHelper { return new FactoryDefinitionHelper($callable, \true); } } if (!\function_exists('ElementorDeps\\DI\\get')) { /** * Helper for referencing another container entry in an object definition. */ function get(string $entryName) : Reference { return new Reference($entryName); } } if (!\function_exists('ElementorDeps\\DI\\env')) { /** * Helper for referencing environment variables. * * @param string $variableName The name of the environment variable. * @param mixed $defaultValue The default value to be used if the environment variable is not defined. */ function env(string $variableName, $defaultValue = null) : EnvironmentVariableDefinition { // Only mark as optional if the default value was *explicitly* provided. $isOptional = 2 === \func_num_args(); return new EnvironmentVariableDefinition($variableName, $isOptional, $defaultValue); } } if (!\function_exists('ElementorDeps\\DI\\add')) { /** * Helper for extending another definition. * * Example: * * 'log.backends' => DI\add(DI\get('My\Custom\LogBackend')) * * or: * * 'log.backends' => DI\add([ * DI\get('My\Custom\LogBackend') * ]) * * @param mixed|array $values A value or an array of values to add to the array. * * @since 5.0 */ function add($values) : ArrayDefinitionExtension { if (!\is_array($values)) { $values = [$values]; } return new ArrayDefinitionExtension($values); } } if (!\function_exists('ElementorDeps\\DI\\string')) { /** * Helper for concatenating strings. * * Example: * * 'log.filename' => DI\string('{app.path}/app.log') * * @param string $expression A string expression. Use the `{}` placeholders to reference other container entries. * * @since 5.0 */ function string(string $expression) : StringDefinition { return new StringDefinition($expression); } } /** * Woostify * * @package woostify */ // Define constants. define( 'WOOSTIFY_VERSION', '2.3.8' ); define( 'WOOSTIFY_PRO_MIN_VERSION', '1.7.2' ); define( 'WOOSTIFY_THEME_DIR', get_template_directory() . '/' ); define( 'WOOSTIFY_THEME_URI', get_template_directory_uri() . '/' ); // Woostify svgs icon. require_once WOOSTIFY_THEME_DIR . 'inc/class-woostify-icon.php'; // Woostify functions, hooks. require_once WOOSTIFY_THEME_DIR . 'inc/woostify-functions.php'; require_once WOOSTIFY_THEME_DIR . 'inc/woostify-template-hooks.php'; require_once WOOSTIFY_THEME_DIR . 'inc/woostify-template-builder.php'; require_once WOOSTIFY_THEME_DIR . 'inc/woostify-template-functions.php'; // Woostify generate css. require_once WOOSTIFY_THEME_DIR . 'inc/customizer/class-woostify-webfont-loader.php'; require_once WOOSTIFY_THEME_DIR . 'inc/customizer/class-woostify-fonts-helpers.php'; require_once WOOSTIFY_THEME_DIR . 'inc/customizer/class-woostify-get-css.php'; // Woostify customizer. require_once WOOSTIFY_THEME_DIR . 'inc/class-woostify.php'; require_once WOOSTIFY_THEME_DIR . 'inc/customizer/class-woostify-customizer.php'; // Woostify woocommerce. if ( woostify_is_woocommerce_activated() ) { require_once WOOSTIFY_THEME_DIR . 'inc/woocommerce/class-woostify-woocommerce.php'; require_once WOOSTIFY_THEME_DIR . 'inc/woocommerce/class-woostify-adjacent-products.php'; require_once WOOSTIFY_THEME_DIR . 'inc/woocommerce/woostify-woocommerce-template-functions.php'; require_once WOOSTIFY_THEME_DIR . 'inc/woocommerce/woostify-woocommerce-archive-product-functions.php'; require_once WOOSTIFY_THEME_DIR . 'inc/woocommerce/woostify-woocommerce-single-product-functions.php'; require_once WOOSTIFY_THEME_DIR . 'inc/woocommerce/woostify-woocommerce-query-update.php'; } // Woostify admin. if ( is_admin() ) { require_once WOOSTIFY_THEME_DIR . 'inc/admin/class-woostify-admin.php'; require_once WOOSTIFY_THEME_DIR . 'inc/admin/class-woostify-meta-boxes.php'; } // Compatibility. require_once WOOSTIFY_THEME_DIR . 'inc/compatibility/class-woostify-divi-builder.php'; /** * Note: Do not add any custom code here. Please use a custom plugin so that your customizations aren't lost during updates. */