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,235 @@
<?php
/**
* Group CRUD Helpers
*
* @since 2.0.0
* @package AdvancedAds
* @author Advanced Ads <info@wpadvancedads.com>
*
* Content:
* 1. Template
* 2. Repositories functions
* 3. CRUD functions
* 4. Conditional functions
* 5. Getter functions
* 6. Finder functions
*/
use AdvancedAds\Abstracts\Group;
use AdvancedAds\Groups\Group_Types;
use AdvancedAds\Groups\Group_Factory;
use AdvancedAds\Interfaces\Group_Type;
use AdvancedAds\Groups\Group_Repository;
/** 1. Template --------------- */
/**
* Get the group object.
*
* @param Group|WP_Term|int|bool $group_id Group instance, term instance or numeric.
* @param string $new_type Change type of group.
* @param array $args Additional arguments.
*
* @return string|mixed The group output or whatever entity or string that is overriding the return value.
*/
function get_the_group( $group_id = 0, $new_type = '', $args = [] ) {
if ( ! \Advanced_Ads::get_instance()->can_display_ads() ) {
return '';
}
if ( defined( 'ADVANCED_ADS_DISABLE_CHANGE' ) && ADVANCED_ADS_DISABLE_CHANGE ) {
$args = [];
}
// Early bail!!
// TODO: remove later once we move to new hooks.
if ( isset( $args['override'] ) ) {
return $args['override'];
}
$group = is_a_group( $group_id ) ? $group_id : wp_advads_get_group( $group_id, $new_type );
if ( ! $group || 0 === $group->get_id() ) {
return '';
}
$args = wp_advads_default_entity_arguments( 'group', $group->get_id(), $args );
wp_advads_set_additional_args( $group, $args );
$override = apply_filters( 'advanced-ads-ad-select-override-by-group', false, $group, $group->get_ordered_ad_ids(), $args );
if ( false !== $override ) {
return $override;
}
return $group->output();
}
/**
* Echo an ad from an ad group
*
* @since 1.0.0
*
* @param int $id ID of the ad group.
* @param array $args Additional arguments.
*
* @return void
*/
function the_ad_group( $id = 0, $args = [] ): void {
echo get_the_group( $id, '', $args ); // phpcs:ignore
}
/* 2. Repositories ------------------- */
/**
* Get Group Factory
*
* @return Group_Factory
*/
function wp_advads_get_group_factory(): Group_Factory {
return wp_advads()->groups->factory;
}
/**
* Get Group Repository
*
* @return Group_Repository
*/
function wp_advads_get_group_repository(): Group_Repository {
return wp_advads()->groups->repository;
}
/**
* Get Group Types
*
* @return Group_Types
*/
function wp_advads_get_group_type_manager(): Group_Types {
return wp_advads()->groups->types;
}
/* 3. CRUD ------------------- */
/**
* Create an empty group object
*
* @param string $type Type of group to create.
*
* @return Group|bool Group object or false if the group type not found.
*/
function wp_advads_create_new_group( $type = 'default' ) {
return wp_advads_get_group_factory()->create_group( $type );
}
/**
* Delete an group from the database.
*
* @param int|Group $group Group object or Id.
*
* @return void
*/
function wp_advads_delete_group( &$group ): void {
if ( ! $group instanceof Group ) {
$group = wp_advads_get_group( $group );
}
$group->delete();
}
/**
* Create missing group type.
*
* @param string $type Missing type.
*
* @return void
*/
function wp_advads_create_group_type( $type ): void {
wp_advads_get_group_type_manager()->create_missing( $type );
}
/**
* Register custom group type.
*
* @param string $classname Type class name.
*
* @return void
*/
function wp_advads_register_group_type( $classname ): void {
wp_advads_get_group_type_manager()->register_type( $classname );
}
/* 4. Conditional ------------------- */
/**
* Has group type.
*
* @param string $type Type to check.
*
* @return bool
*/
function wp_advads_has_group_type( $type ): bool {
return wp_advads_get_group_type_manager()->has_type( $type );
}
/**
* Checks whether the given variable is a group.
*
* @param mixed $thing The variable to check.
*
* @return bool
*/
function is_a_group( $thing ): bool {
return $thing instanceof Group;
}
/* 5. Getter ------------------- */
/**
* Get all groups object.
*
* @return Group[]
*/
function wp_advads_get_all_groups(): array {
return wp_advads_get_group_repository()->get_all_groups();
}
/**
* Get all group as dropdown.
*
* @return array
*/
function wp_advads_get_groups_dropdown() {
return wp_advads_get_group_repository()->get_groups_dropdown();
}
/**
* Get the registered group type.
*
* @param string $type Type to get.
*
* @return Group_Type|bool
*/
function wp_advads_get_group_type( $type ) {
return wp_advads_get_group_type_manager()->get_type( $type );
}
/**
* Get the registered group types.
*
* @return Group_Type[]
*/
function wp_advads_get_group_types() {
return wp_advads_get_group_type_manager()->get_types();
}
/* 6. Finder ------------------- */
/**
* Get the group object.
*
* @param Group|WP_Term|int|bool $group_id Group instance, term instance or numeric.
* @param string $new_type Change type of group.
*
* @return Group|bool Group object or false if the group cannot be loaded.
*/
function wp_advads_get_group( $group_id = false, $new_type = '' ) {
return wp_advads_get_group_factory()->get_group( $group_id, $new_type );
}