Commit inicial - WordPress Análisis de Precios Unitarios

- WordPress core y plugins
- Tema Twenty Twenty-Four configurado
- Plugin allow-unfiltered-html.php simplificado
- .gitignore configurado para excluir wp-config.php y uploads

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
root
2025-11-03 21:04:30 -06:00
commit a22573bf0b
24068 changed files with 4993111 additions and 0 deletions

View File

@@ -0,0 +1,121 @@
<?php
/**
* The placement factory.
*
* @package AdvancedAds
* @author Advanced Ads <info@wpadvancedads.com>
* @since 1.50.0
*/
namespace AdvancedAds\Placements;
use Exception;
use AdvancedAds\Constants;
use AdvancedAds\Abstracts\Factory;
use AdvancedAds\Abstracts\Placement;
use AdvancedAds\Placements\Placement_Standard;
defined( 'ABSPATH' ) || exit;
/**
* Placements Factory.
*/
class Placement_Factory extends Factory {
/**
* Create an empty placement object
*
* @param string $type Type of placement to create.
*
* @return Placement|bool Placement object or false if the placement type not found.
*/
public function create_placement( $type = 'default' ) {
$placement_type = wp_advads_get_placement_type( $type );
if ( ! $placement_type ) {
return false;
}
$classname = $placement_type->get_classname();
// Create placement.
$placement = new $classname( 0 );
$placement->set_type( $placement_type->get_id() );
return $placement;
}
/**
* Get the placement object.
*
* @param Placement|WP_Post|int|bool $placement_id Placement instance, post instance, numeric or false to use global $post.
* @param string $new_type Change type of placement.
*
* @return Placement|bool Placement object or false if the placement cannot be loaded.
*/
public function get_placement( $placement_id = false, $new_type = '' ) {
$placement_id = $this->get_placement_id( $placement_id );
if ( ! $placement_id ) {
return false;
}
$placement_type = '' !== $new_type ? $new_type : $this->get_placement_type( $placement_id );
$classname = $this->get_classname( wp_advads_get_placement_type_manager(), $placement_type );
try {
return new $classname( $placement_id );
} catch ( Exception $e ) {
return false;
}
return new Placement_Standard();
}
/**
* Get the type of the placement.
*
* @param int $placement_id Placement ID.
*
* @return string The type of the placement.
*/
private function get_placement_type( $placement_id ): string {
// Allow the overriding of the lookup in this function. Return the placement type here.
$override = apply_filters( 'advanced-ads-placement-type', false, $placement_id );
if ( $override ) {
return $override;
}
$options = get_post_meta( $placement_id, 'type', true );
return $options['type'] ?? 'default';
}
/**
* Get the placement ID depending on what was passed.
*
* @param Placement|WP_Post|int|bool $placement Placement instance, post instance, numeric or false to use global $post.
*
* @return int|bool false on failure
*/
private function get_placement_id( $placement ) {
global $post;
if ( false === $placement && isset( $post, $post->ID ) && Constants::POST_TYPE_AD === get_post_type( $post->ID ) ) {
return absint( $post->ID );
}
if ( is_numeric( $placement ) ) {
return $placement;
}
if ( is_a_placement( $placement ) ) {
return $placement->get_id();
}
if ( ! empty( $placement->ID ) ) {
return $placement->ID;
}
return false;
}
}