tern_data['categories'] as $key => $category ) { $category_slug = _wp_to_kebab_case( $category ); $pattern_data['categories'][ $key ] = $category_slug; register_block_pattern_category( $category_slug, // phpcs:ignore WordPress.WP.I18n.NonSingularStringLiteralText array( 'label' => __( $category, 'woocommerce' ) ) ); } register_block_pattern( $pattern_data['slug'], $pattern_data ); } } /** * Update the patterns content when the store description is changed. * * @param string $option The option name. * @param string $value The option value. */ public function schedule_on_option_update( $option, $value ) { $last_business_description = get_option( 'last_business_description_with_ai_content_generated' ); if ( $last_business_description === $value ) { return; } $this->schedule_patterns_content_update( $value ); } /** * Update the patterns content when the WooCommerce Blocks plugin is updated. * * @param \WP_Upgrader $upgrader_object WP_Upgrader instance. * @param array $options Array of bulk item update data. */ public function schedule_on_plugin_update( $upgrader_object, $options ) { if ( 'update' === $options['action'] && 'plugin' === $options['type'] && isset( $options['plugins'] ) ) { foreach ( $options['plugins'] as $plugin ) { if ( str_contains( $plugin, 'woocommerce-gutenberg-products-block.php' ) || str_contains( $plugin, 'woocommerce.php' ) ) { $business_description = get_option( 'woo_ai_describe_store_description' ); if ( $business_description ) { $this->schedule_patterns_content_update( $business_description ); } } } } } /** * Update the patterns content when the store description is changed. * * @param string $business_description The business description. */ public function schedule_patterns_content_update( $business_description ) { if ( ! class_exists( 'WooCommerce' ) ) { return; } $action_scheduler = WP_PLUGIN_DIR . '/woocommerce/packages/action-scheduler/action-scheduler.php'; if ( ! file_exists( $action_scheduler ) ) { return; } require_once $action_scheduler; as_schedule_single_action( time(), 'woocommerce_update_patterns_content', array( $business_description ) ); } /** * Update the patterns content. * * @param string $value The new value saved for the add_option_woo_ai_describe_store_description option. * * @return bool|string|\WP_Error */ public function update_patterns_content( $value ) { $allow_ai_connection = get_option( 'woocommerce_blocks_allow_ai_connection' ); if ( ! $allow_ai_connection ) { return new \WP_Error( 'ai_connection_not_allowed', __( 'AI content generation is not allowed on this store. Update your store settings if you wish to enable this feature.', 'woocommerce' ) ); } $ai_connection = new Connection(); $site_id = $ai_connection->get_site_id(); if ( is_wp_error( $site_id ) ) { return $site_id->get_error_message(); } $token = $ai_connection->get_jwt_token( $site_id ); if ( is_wp_error( $token ) ) { return $token->get_error_message(); } $business_description = get_option( 'woo_ai_describe_store_description' ); $images = ( new Pexels() )->get_images( $ai_connection, $token, $business_description ); if ( is_wp_error( $images ) ) { return $images->get_error_message(); } $populate_patterns = ( new PatternUpdater() )->generate_content( $ai_connection, $token, $images, $business_description ); if ( is_wp_error( $populate_patterns ) ) { return $populate_patterns->get_error_message(); } $populate_products = ( new ProductUpdater() )->generate_content( $ai_connection, $token, $images, $business_description ); if ( is_wp_error( $populate_products ) ) { return $populate_products->get_error_message(); } return true; } /** * Filter the patterns dictionary to get the pattern data corresponding to the pattern slug. * * @param array $dictionary The patterns dictionary. * @param string $slug The pattern slug. * * @return array|null */ private function get_pattern_from_dictionary( $dictionary, $slug ) { foreach ( $dictionary as $pattern_dictionary ) { if ( isset( $pattern_dictionary['slug'] ) && $pattern_dictionary['slug'] === $slug ) { return $pattern_dictionary; } } return null; } }