Skip to main content

Opciones de WordPress

El plugin Tokko almacena todas sus configuraciones en las opciones de WordPress (wp_options). Esta referencia documentan todas las opciones disponibles, sus valores, tipos y cómo accederlas.

Configuración de API

Estas opciones contienen los detalles de conexión con Tokko Broker.

thi_api_key

Clave de autenticación para la API de Tokko Broker.
$api_key = get_option('thi_api_key');
PropiedadValor
Tipostring
Valor predeterminado” (vacío)
Requerido
SensibleSí - No mostrar en formularios públicos
DescripciónClave de autenticación de TokkoBroker API. Se obtiene en panel de control de Tokko.
Esta es una clave sensible. No la expongas en código público o repositorios Git.

thi_language

Idioma de la API de Tokko.
$language = get_option('thi_language', 'es');
PropiedadValor
Tipostring
Valor predeterminado’es’
Valores válidos’es’, ‘en’, ‘pt’, ‘fr’
DescripciónIdioma de respuesta de la API de Tokko.

thi_plugin_language

Idioma de la interfaz del plugin.
$lang = get_option('thi_plugin_language', 'es_ES');
PropiedadValor
Tipostring
Valor predeterminado’es_ES’
DescripciónCódigo de idioma para traducción del plugin en WordPress.

Configuración de sincronización

thi_sync_option

Tipo de sincronización configurado.
$sync_type = get_option('thi_sync_option', 'horariu');
PropiedadValor
Tipostring
Valor predeterminado’hourly’
Valores válidos’hourly’, ‘twicedaily’, ‘daily’, ‘custom’
DescripciónFrecuencia de sincronización automática.

thi_custom_interval_value

Valor personalizado en minutos para sincronización custom.
$interval = get_option('thi_custom_interval_value', 60);
PropiedadValor
Tipoint
Valor predeterminado60
Rango válido10 - 1440
UnidadMinutos
DescripciónSe usa solo cuando thi_sync_option es ‘custom’.

thi_sync_developments

Habilita sincronización de desarrollos.
$sync_devs = get_option('thi_sync_developments', false);
PropiedadValor
Tipobool
Valor predeterminadofalse
DescriciónSi está habilitado, también sincroniza desarrollos además de propiedades.

Configuración de visualización

thi_default_map_enabled

Muestra mapa por defecto en páginas de propiedad.
$map_enabled = get_option('thi_default_map_enabled', true);
PropiedadValor
Tipobool
Valor predeterminadotrue
DescripciónControla si los mapas de ubicación se muestran automáticamente.

thi_generate_thumbnails

Genera miniaturas de imágenes al sincronizar.
$thumbnails = get_option('thi_generate_thumbnails', true);
PropiedadValor
Tipobool
Valor predeterminadotrue
DescripciónSi está activo, crea miniaturas de imágenes para mejor rendimiento.

thi_enable_secondary_url

Habilita URL secundaria para propiedades.
$secondary = get_option('thi_enable_secondary_url', false);
PropiedadValor
Tipobool
Valor predeterminadofalse
DescripciónPermite URLs alternativas para propiedades.

thi_enable_tokko_broker_url

Enlaza a Tokko Broker en lugar de mostrar en sitio.
$tokko_url = get_option('thi_enable_tokko_broker_url', false);
PropiedadValor
Tipobool
Valor predeterminadofalse
DescripciónSi está activo, las propiedades redirigen a Tokko Broker.

thi_use_address_as_title

Usa dirección como título de propiedad.
$address_title = get_option('thi_use_address_as_title', false);
PropiedadValor
Tipobool
Valor predeterminadofalse
DescripciónSi está habilitado, las direcciones se usan como títulos principales.

thi_hide_property_address

Oculta la dirección completa de propiedades.
$hide_address = get_option('thi_hide_property_address', false);
PropiedadValor
Tipobool
Valor predeterminadofalse
DescripciónOculta la dirección completa por privacidad.

Configuración de búsqueda avanzada

thi_enhanced_search_enabled

Activa búsqueda mejorada de propiedades.
$search_enabled = get_option('thi_enhanced_search_enabled', false);
PropiedadValor
Tipobool
Valor predeterminadofalse
DescripciónHabilita filtros avanzados y búsqueda personalizada.

thi_enhanced_search_fields

Campos habilitados para búsqueda avanzada.
$fields = get_option('thi_enhanced_search_fields', []);
PropiedadValor
Tipoarray
Valor predeterminado[] (vacío)
DescripciónLista de campos disponibles en búsqueda avanzada.

thi_age_range_slider_color

Color del slider de edad de construcción.
$color = get_option('thi_age_range_slider_color', '#3498db');
PropiedadValor
Tipostring
Valor predeterminado’#3498db’
FormatoCódigo hexadecimal de color
DescripciónColor personalizado para rango de años en búsqueda.

thi_age_range_slider_label

Etiqueta del slider de edad de construcción.
$label = get_option('thi_age_range_slider_label', 'Años de construcción');
PropiedadValor
Tipostring
Valor predeterminado’Años de construcción’
DescripciónEtiqueta visible para el rango de edad.

thi_age_range_slider_half_map_enabled

Muestra slider a mitad de mapa.
$half_map = get_option('thi_age_range_slider_half_map_enabled', false);
PropiedadValor
Tipobool
Valor predeterminadofalse
DescripciónPosiciona el slider al lado del mapa en lugar de arriba.

Configuración de agentes

thi_enable_agent_sync

Habilita sincronización de agentes desde Tokko.
$agent_sync = get_option('thi_enable_agent_sync', false);
PropiedadValor
Tipobool
Valor predeterminadofalse
DescripciónSi está activo, sincroniza agentes de Tokko como posts en WordPress.

thi_agent_mobile_is_whatsapp

Trata números móviles de agentes como WhatsApp.
$whatsapp = get_option('thi_agent_mobile_is_whatsapp', false);
PropiedadValor
Tipobool
Valor predeterminadofalse
DescripciónConvierte números móviles a enlaces de WhatsApp.

thi_download_agent_images

Descarga imágenes de agentes localmente.
$download_imgs = get_option('thi_download_agent_images', true);
PropiedadValor
Tipobool
Valor predeterminadotrue
DescripciónSi está habilitado, descarga y almacena imágenes de agentes en el servidor.

thi_auto_assign_agent_id

ID de agente para asignación automática de propiedades.
$agent_id = get_option('thi_auto_assign_agent_id', 0);
PropiedadValor
Tipoint
Valor predeterminado0 (ninguno)
DescripciónID de WordPress del agente que recibe propiedades sin agente asignado.

Configuración de imágenes

thi_image_quality

Calidad de procesamiento de imágenes.
$quality = get_option('thi_image_quality', 'medium');
PropiedadValor
Tipostring
Valor predeterminado’medium’
Valores válidos’low’, ‘medium’, ‘high’
DescripciónDetermina resolución y calidad de imágenes sincronizadas.
ImpactoAfecta tamaño de almacenamiento y velocidad de carga.

Configuración de contacto

thi_enable_contact_integration

Habilita integración de formularios de contacto.
$contact_enabled = get_option('thi_enable_contact_integration', false);
PropiedadValor
Tipobool
Valor predeterminadofalse
DescripciónSi está activo, conecta formularios de contacto con Tokko y CRM.

Estado y rastreo

Estas opciones son actualizadas automáticamente por el plugin y generalmente no deben modificarse manualmente.

thi_last_sync_time

Timestamp de la última sincronización completada.
$last_sync = get_option('thi_last_sync_time', null);
PropiedadValor
Tipostring (ISO 8601)
Valor predeterminadonull
DescripciónRegistro automático de cuándo se completó la última sincronización.

thi_last_sync_metadata

Información detallada de la última sincronización.
$metadata = get_option('thi_last_sync_metadata', []);

// Estructura típica:
echo $metadata['properties_created']; // int
echo $metadata['properties_updated']; // int
echo $metadata['images_processed'];    // int
echo $metadata['duration'];            // float (segundos)
echo $metadata['status'];              // 'success', 'error', 'warning'
PropiedadValor
Tipoarray
EstructuraArray con claves: created, updated, deleted, images_processed, duration, status
DescripciónMetadatos detallados de la última sincronización.

thi_recent_sync_results

Historial de últimas sincronizaciones (máximo 10).
$results = get_option('thi_recent_sync_results', []);

foreach ($results as $sync) {
    echo $sync['timestamp'] . ': ' . $sync['status'];
}
PropiedadValor
Tipoarray
DescripciónArray de objetos con resultados de últimas sincronizaciones.

thi_sync_error_history

Historial de errores de sincronización.
$errors = get_option('thi_sync_error_history', []);

foreach ($errors as $error) {
    echo 'Fecha: ' . $error['timestamp'];
    echo 'Error: ' . $error['message'];
    echo 'Código: ' . $error['code'];
}
PropiedadValor
Tipoarray
DescripciónLista de errores ocurridos durante sincronización.
RetenciónÚltimos 50 errores

thi_intelligent_sync_ready

Indica si sincronización inteligente está lista.
$ready = get_option('thi_intelligent_sync_ready', false);
PropiedadValor
Tipobool
DescripciónSe establece a true cuando el sistema está listo para detección de cambios.

thi_plugin_version

Versión actual del plugin instalado.
$version = get_option('thi_plugin_version', '1.0.0');
PropiedadValor
Tipostring
DescripciónVersión del plugin. Se actualiza automáticamente al actualizar.

thi_last_api_connection

Timestamp del último contacto exitoso con API.
$last_api = get_option('thi_last_api_connection', null);
PropiedadValor
Tipostring (ISO 8601)
DescripciónAyuda a detectar problemas de conectividad con Tokko.

thi_last_api_response_time

Tiempo de respuesta (en ms) de la última llamada API.
$response_time = get_option('thi_last_api_response_time', 0);

echo 'Última respuesta: ' . $response_time . 'ms';
PropiedadValor
Tipoint
UnidadMilisegundos
DescripciónÚtil para monitorear rendimiento de conexión con Tokko.

Acceso a opciones en código

Obtener opciones

// Obtener con valor predeterminado
$api_key = get_option('thi_api_key', 'default_value');

// Obtener sin valor predeterminado
$api_key = get_option('thi_api_key');

// Obtener y decodificar JSON
$fields = json_decode(get_option('thi_enhanced_search_fields', '[]'), true);

Actualizar opciones

// Actualizar simple
update_option('thi_api_key', 'nueva-clave');

// Actualizar con serialización automática
update_option('thi_enhanced_search_fields', [
    'precio',
    'dormitorios'
]);

// Usar add_option si es nueva
add_option('thi_custom_option', 'valor', '', 'yes');

Eliminar opciones

// Eliminar opción
delete_option('thi_custom_option');

Mejores prácticas

No edites directamente en la base de datos. Siempre usa funciones de WordPress para garantizar sanitización y validación correctas.
Usa nombres con prefijo al crear opciones personalizadas para evitar conflictos:
// ✅ CORRECTO
add_option('thi_my_custom_option', $value);

// ❌ INCORRECTO
add_option('custom_option', $value);
// ✅ BUEN EJEMPLO - Actualizar opción con validación
function update_my_option($value) {
    // Validar
    if (!is_array($value)) {
        return false;
    }

    // Sanitizar
    $sanitized = array_map('sanitize_text_field', $value);

    // Actualizar
    return update_option('thi_my_option', $sanitized);
}

Exportar/Importar opciones

// Exportar todas las opciones de Tokko
$tokko_options = [];
$all_options = wp_load_alloptions();

foreach ($all_options as $name => $value) {
    if (strpos($name, 'thi_') === 0) {
        $tokko_options[$name] = $value;
    }
}

echo json_encode($tokko_options);

// Importar opciones
$backup = json_decode(file_get_contents('backup.json'), true);

foreach ($backup as $name => $value) {
    update_option($name, $value);
}