feat: initial ACRIB WordPress deployment
- WordPress 6.9.4 (es_ES) with Kadence theme - Homepage: Hero, La Asociación, Pilares, Beneficios, Eventos, Miembros, Hazte Miembro, Contacto - Brand identity: #13294b navy, #a12932 burgundy, #c69c48 gold - Fonts: Raleway (headings) + Source Sans 3 (body) + Lato (UI) - Plugins: Kadence Blocks, Polylang, Contact Form 7 - Custom CSS with full brand styling and responsive layout - HTTPS enforced via wp-config.php proxy detection
This commit is contained in:
@@ -0,0 +1,105 @@
|
||||
<?php
|
||||
/**
|
||||
* @package Polylang
|
||||
*/
|
||||
|
||||
namespace WP_Syntex\Polylang\Options\Primitive;
|
||||
|
||||
use WP_Syntex\Polylang\Options\Options;
|
||||
use WP_Syntex\Polylang\Options\Abstract_Option;
|
||||
|
||||
defined( 'ABSPATH' ) || exit;
|
||||
|
||||
/**
|
||||
* Class defining a map option.
|
||||
*
|
||||
* @since 3.8
|
||||
*/
|
||||
abstract class Abstract_Map extends Abstract_Option {
|
||||
/**
|
||||
* Option value.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $value;
|
||||
|
||||
/**
|
||||
* Returns the JSON schema part specific to this option.
|
||||
*
|
||||
* @since 3.8
|
||||
*
|
||||
* @return array Partial schema.
|
||||
*/
|
||||
protected function get_data_structure(): array {
|
||||
return array_merge(
|
||||
$this->get_inner_structure(),
|
||||
array(
|
||||
'type' => 'object', // Correspond to associative array in PHP, @see{https://developer.wordpress.org/rest-api/extending-the-rest-api/schema/#primitive-types}.
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Removes a key from the map.
|
||||
*
|
||||
* @since 3.8
|
||||
*
|
||||
* @param string $key The key to remove.
|
||||
* @return bool True if the key has been removed. False otherwise.
|
||||
*/
|
||||
public function remove( string $key ): bool {
|
||||
if ( ! array_key_exists( $key, $this->value ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$this->value[ $key ] = $this->reset_value( $key );
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds an item to the map.
|
||||
*
|
||||
* @since 3.8
|
||||
*
|
||||
* @param array<string, mixed> $item The item(s) to add. Must be a key-value pair.
|
||||
* @param Options $options The options instance.
|
||||
* @return bool True if the value was added successfully. False otherwise.
|
||||
*/
|
||||
public function add( $item, Options $options ): bool {
|
||||
if ( ! is_array( $item ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
/** @var array<string, mixed> $old_value */
|
||||
$old_value = $this->get();
|
||||
$updated_value = array_merge(
|
||||
$old_value,
|
||||
$item
|
||||
);
|
||||
|
||||
return $this->set(
|
||||
$updated_value,
|
||||
$options
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the JSON schema part specific to the inner structure of this option.
|
||||
*
|
||||
* @since 3.8
|
||||
*
|
||||
* @return array Partial schema.
|
||||
*/
|
||||
abstract protected function get_inner_structure(): array;
|
||||
|
||||
/**
|
||||
* Returns the reset value for a key.
|
||||
*
|
||||
* @since 3.8
|
||||
*
|
||||
* @param string $key The key to reset.
|
||||
* @return mixed The reset value.
|
||||
*/
|
||||
abstract protected function reset_value( string $key );
|
||||
}
|
||||
Reference in New Issue
Block a user