........................................................... .......................................... ............................................... ................................ ??????????????????????????????? ??????????????????????????????? ??????????????????????????????? ................................ ................................. ............................... >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>. class-wp-widget-area-customize-control.php000064400000003267152222507600014704 0ustar00json[ $key ] = $this->$key; } } /** * Renders the control's content. * * @since 3.9.0 */ public function render_content() { $id = 'reorder-widgets-desc-' . str_replace( array( '[', ']' ), array( '-', '' ), $this->id ); ?>

  • setting->term_id; return $exported; } } class-wp-customize-nav-menus-panel.php000064400000006355152222507600014044 0ustar00render_screen_options( array( 'wrap' => false ) ); } /** * Returns the advanced options for the nav menus page. * * Link title attribute added as it's a relatively advanced concept for new users. * * @since 4.3.0 * @deprecated 4.5.0 Deprecated in favor of wp_nav_menu_manage_columns(). */ public function wp_nav_menu_manage_columns() { _deprecated_function( __METHOD__, '4.5.0', 'wp_nav_menu_manage_columns' ); require_once ABSPATH . 'wp-admin/includes/nav-menu.php'; return wp_nav_menu_manage_columns(); } /** * An Underscore (JS) template for this panel's content (but not its container). * * Class variables for this panel class are available in the `data` JS object; * export custom variables by overriding WP_Customize_Panel::json(). * * @since 4.3.0 * * @see WP_Customize_Panel::print_template() */ protected function content_template() { ?>
  • {{ data.title }}' ); ?>
    <# if ( data.description ) { #>
    {{{ data.description }}}
    <# } #>
    render_screen_options(); ?>
  • <# if ( data.label ) { #> {{ data.label }} <# } #> <# if ( data.attachment && data.attachment.id ) { #>
    <# if ( data.attachment.sizes ) { #>
    {{
								data.attachment.alt ?
									wp.i18n.sprintf(
										<?php
										/* translators: %s: The selected image alt text. */
										echo wp_json_encode( __( 'App icon preview: Current image: %s' ) )
										?>
										,
										data.attachment.alt
									) :
									wp.i18n.sprintf(
										<?php
										/* translators: %s: The selected image filename. */
										echo wp_json_encode( __( 'App icon preview: The current image has no alternative text. The file name is: %s' ) );
										?>
										,
										data.attachment.filename
									)
							}}
    {{
										data.attachment.alt ?
											wp.i18n.sprintf(
												<?php
												/* translators: %s: The selected image alt text. */
												echo wp_json_encode( __( 'Browser icon preview: Current image: %s' ) );
												?>
												,
												data.attachment.alt
											) :
											wp.i18n.sprintf(
												<?php
												/* translators: %s: The selected image filename. */
												echo wp_json_encode( __( 'Browser icon preview: The current image has no alternative text. The file name is: %s' ) );
												?>
												,
												data.attachment.filename
											)
									}}
    <# } #>
    <# if ( data.canUpload ) { #> <# } #>
    <# } else { #>
    <# if ( data.canUpload ) { #> <# } #>
    <# if ( data.defaultAttachment ) { #> <# } #>
    <# } #> <# if ( data.description ) { #> {{{ data.description }}} <# } #> __( 'Header Image' ), 'settings' => array( 'default' => 'header_image', 'data' => 'header_image_data', ), 'section' => 'header_image', 'removed' => 'remove-header', 'get_url' => 'get_header_image', ) ); } /** */ public function enqueue() { wp_enqueue_media(); wp_enqueue_script( 'customize-views' ); $this->prepare_control(); wp_localize_script( 'customize-views', '_wpCustomizeHeader', array( 'data' => array( 'width' => absint( get_theme_support( 'custom-header', 'width' ) ), 'height' => absint( get_theme_support( 'custom-header', 'height' ) ), 'flex-width' => absint( get_theme_support( 'custom-header', 'flex-width' ) ), 'flex-height' => absint( get_theme_support( 'custom-header', 'flex-height' ) ), 'currentImgSrc' => $this->get_current_image_src(), ), 'nonces' => array( 'add' => wp_create_nonce( 'header-add' ), 'remove' => wp_create_nonce( 'header-remove' ), ), 'uploads' => $this->uploaded_headers, 'defaults' => $this->default_headers, ) ); parent::enqueue(); } /** * @global Custom_Image_Header $custom_image_header */ public function prepare_control() { global $custom_image_header; if ( empty( $custom_image_header ) ) { return; } add_action( 'customize_controls_print_footer_scripts', array( $this, 'print_header_image_template' ) ); // Process default headers and uploaded headers. $custom_image_header->process_default_headers(); $this->default_headers = $custom_image_header->get_default_header_images(); $this->uploaded_headers = $custom_image_header->get_uploaded_header_images(); } /** */ public function print_header_image_template() { ?> value(); if ( isset( $this->get_url ) ) { $src = call_user_func( $this->get_url, $src ); return $src; } } /** */ public function render_content() { $visibility = $this->get_current_image_src() ? '' : ' style="display:none" '; $width = absint( get_theme_support( 'custom-header', 'width' ) ); $height = absint( get_theme_support( 'custom-header', 'height' ) ); ?>
    ' . $this->label . ''; } ?>

    %s × %s', $width, $height ) ); } elseif ( $width ) { printf( /* translators: %s: Header width in pixels. */ __( 'Click “Add Image” to upload an image file from your computer. Your theme works best with an image with a header width of %s pixels — you’ll be able to crop your image once you upload it for a perfect fit.' ), sprintf( '%s', $width ) ); } else { printf( /* translators: %s: Header height in pixels. */ __( 'Click “Add Image” to upload an image file from your computer. Your theme works best with an image with a header height of %s pixels — you’ll be able to crop your image once you upload it for a perfect fit.' ), sprintf( '%s', $height ) ); } ?>

    manager->get_setting( 'header_image' )->post_value(); } if ( is_array( $value ) && isset( $value['choice'] ) ) { $custom_image_header->set_header_image( $value['choice'] ); } else { $custom_image_header->set_header_image( $value ); } } } class-wp-customize-nav-menu-auto-add-control.php000064400000002142152222507600015724 0ustar00 <# var elementId = _.uniqueId( 'customize-nav-menu-auto-add-control-' ); #> max_year; $data['minYear'] = (int) $this->min_year; $data['allowPastDate'] = (bool) $this->allow_past_date; $data['twelveHourFormat'] = (bool) $this->twelve_hour_format; $data['includeTime'] = (bool) $this->include_time; return $data; } /** * Renders a JS template for the content of date time control. * * @since 4.9.0 */ public function content_template() { $data = array_merge( $this->json(), $this->get_month_choices() ); $timezone_info = $this->get_timezone_info(); $date_format = get_option( 'date_format' ); $date_format = preg_replace( '/(? <# _.defaults( data, ); #> <# var idPrefix = _.uniqueId( 'el' ) + '-'; #> <# if ( data.label ) { #> {{ data.label }} <# } #>
    <# if ( data.description ) { #> {{ data.description }} <# } #>
    <# if ( data.includeTime ) { #>
    <# var maxHour = data.twelveHourFormat ? 12 : 23; #> <# var minHour = data.twelveHourFormat ? 1 : 0; #> : <# if ( data.twelveHourFormat ) { #> <# } #>

    <# } #>
    get_month_abbrev( $wp_locale->get_month( $i ) ); /* translators: 1: Month number (01, 02, etc.), 2: Month abbreviation. */ $months[ $i ]['text'] = sprintf( __( '%1$s-%2$s' ), $i, $month_text ); $months[ $i ]['value'] = $i; } return array( 'month_choices' => $months, ); } /** * Get timezone info. * * @since 4.9.0 * * @return array { * Timezone info. All properties are optional. * * @type string $abbr Timezone abbreviation. Examples: PST or CEST. * @type string $description Human-readable timezone description as HTML. * } */ public function get_timezone_info() { $tz_string = get_option( 'timezone_string' ); $timezone_info = array(); if ( $tz_string ) { try { $tz = new DateTimeZone( $tz_string ); } catch ( Exception $e ) { $tz = ''; } if ( $tz ) { $now = new DateTime( 'now', $tz ); $formatted_gmt_offset = $this->format_gmt_offset( $tz->getOffset( $now ) / HOUR_IN_SECONDS ); $tz_name = str_replace( '_', ' ', $tz->getName() ); $timezone_info['abbr'] = $now->format( 'T' ); $timezone_info['description'] = sprintf( /* translators: 1: Timezone name, 2: Timezone abbreviation, 3: UTC abbreviation and offset, 4: UTC offset. */ __( 'Your timezone is set to %1$s (%2$s), currently %3$s (Coordinated Universal Time %4$s).' ), $tz_name, '' . $timezone_info['abbr'] . '', 'UTC' . $formatted_gmt_offset, $formatted_gmt_offset ); } else { $timezone_info['description'] = ''; } } else { $formatted_gmt_offset = $this->format_gmt_offset( (int) get_option( 'gmt_offset', 0 ) ); $timezone_info['description'] = sprintf( /* translators: 1: UTC abbreviation and offset, 2: UTC offset. */ __( 'Your timezone is set to %1$s (Coordinated Universal Time %2$s).' ), 'UTC' . $formatted_gmt_offset, $formatted_gmt_offset ); } return $timezone_info; } /** * Format GMT Offset. * * @since 4.9.0 * * @see wp_timezone_choice() * * @param float $offset Offset in hours. * @return string Formatted offset. */ public function format_gmt_offset( $offset ) { if ( 0 <= $offset ) { $formatted_offset = '+' . (string) $offset; } else { $formatted_offset = (string) $offset; } $formatted_offset = str_replace( array( '.25', '.5', '.75' ), array( ':15', ':30', ':45' ), $formatted_offset ); return $formatted_offset; } } class-wp-customize-background-image-control.php000064400000002404152222507600015702 0ustar00 __( 'Background Image' ), 'section' => 'background_image', ) ); } /** * Enqueue control related scripts/styles. * * @since 4.1.0 */ public function enqueue() { parent::enqueue(); $custom_background = get_theme_support( 'custom-background' ); wp_localize_script( 'customize-controls', '_wpCustomizeBackground', array( 'defaults' => ! empty( $custom_background[0] ) ? $custom_background[0] : array(), 'nonces' => array( 'add' => wp_create_nonce( 'background-add' ), ), ) ); } } class-wp-customize-partial.php000064400000024510152222507600012463 0ustar00$key = $args[ $key ]; } } $this->component = $component; $this->id = $id; $this->id_data['keys'] = preg_split( '/\[/', str_replace( ']', '', $this->id ) ); $this->id_data['base'] = array_shift( $this->id_data['keys'] ); if ( empty( $this->render_callback ) ) { $this->render_callback = array( $this, 'render_callback' ); } // Process settings. if ( ! isset( $this->settings ) ) { $this->settings = array( $id ); } elseif ( is_string( $this->settings ) ) { $this->settings = array( $this->settings ); } if ( empty( $this->primary_setting ) ) { $this->primary_setting = current( $this->settings ); } } /** * Retrieves parsed ID data for multidimensional setting. * * @since 4.5.0 * * @return array { * ID data for multidimensional partial. * * @type string $base ID base. * @type array $keys Keys for multidimensional array. * } */ final public function id_data() { return $this->id_data; } /** * Renders the template partial involving the associated settings. * * @since 4.5.0 * * @param array $container_context Optional. Array of context data associated with the target container (placement). * Default empty array. * @return string|array|false The rendered partial as a string, raw data array (for client-side JS template), * or false if no render applied. */ final public function render( $container_context = array() ) { $partial = $this; $rendered = false; if ( ! empty( $this->render_callback ) ) { ob_start(); $return_render = call_user_func( $this->render_callback, $this, $container_context ); $ob_render = ob_get_clean(); if ( null !== $return_render && '' !== $ob_render ) { _doing_it_wrong( __FUNCTION__, __( 'Partial render must echo the content or return the content string (or array), but not both.' ), '4.5.0' ); } /* * Note that the string return takes precedence because the $ob_render may just\ * include PHP warnings or notices. */ $rendered = null !== $return_render ? $return_render : $ob_render; } /** * Filters partial rendering. * * @since 4.5.0 * * @param string|array|false $rendered The partial value. Default false. * @param WP_Customize_Partial $partial WP_Customize_Setting instance. * @param array $container_context Optional array of context data associated with * the target container. */ $rendered = apply_filters( 'customize_partial_render', $rendered, $partial, $container_context ); /** * Filters partial rendering for a specific partial. * * The dynamic portion of the hook name, `$partial->ID` refers to the partial ID. * * @since 4.5.0 * * @param string|array|false $rendered The partial value. Default false. * @param WP_Customize_Partial $partial WP_Customize_Setting instance. * @param array $container_context Optional array of context data associated with * the target container. */ $rendered = apply_filters( "customize_partial_render_{$partial->id}", $rendered, $partial, $container_context ); return $rendered; } /** * Default callback used when invoking WP_Customize_Control::render(). * * Note that this method may echo the partial *or* return the partial as * a string or array, but not both. Output buffering is performed when this * is called. Subclasses can override this with their specific logic, or they * may provide an 'render_callback' argument to the constructor. * * This method may return an HTML string for straight DOM injection, or it * may return an array for supporting Partial JS subclasses to render by * applying to client-side templating. * * @since 4.5.0 * * @param WP_Customize_Partial $partial Partial. * @param array $context Context. * @return string|array|false */ public function render_callback( WP_Customize_Partial $partial, $context = array() ) { unset( $partial, $context ); return false; } /** * Retrieves the data to export to the client via JSON. * * @since 4.5.0 * * @return array Array of parameters passed to the JavaScript. */ public function json() { $exports = array( 'settings' => $this->settings, 'primarySetting' => $this->primary_setting, 'selector' => $this->selector, 'type' => $this->type, 'fallbackRefresh' => $this->fallback_refresh, 'containerInclusive' => $this->container_inclusive, ); return $exports; } /** * Checks if the user can refresh this partial. * * Returns false if the user cannot manipulate one of the associated settings, * or if one of the associated settings does not exist. * * @since 4.5.0 * * @return bool False if user can't edit one of the related settings, * or if one of the associated settings does not exist. */ final public function check_capabilities() { if ( ! empty( $this->capability ) && ! current_user_can( $this->capability ) ) { return false; } foreach ( $this->settings as $setting_id ) { $setting = $this->component->manager->get_setting( $setting_id ); if ( ! $setting || ! $setting->check_capabilities() ) { return false; } } return true; } } class-wp-customize-background-image-setting.php000064400000001177152222507600015705 0ustar00 <# if ( data.description ) { #>

    {{ data.description }}

    <# } #> id_data['base'] ) { throw new Exception( 'Expected custom_css id_base.' ); } if ( 1 !== count( $this->id_data['keys'] ) || empty( $this->id_data['keys'][0] ) ) { throw new Exception( 'Expected single stylesheet key.' ); } $this->stylesheet = $this->id_data['keys'][0]; } /** * Add filter to preview post value. * * @since 4.7.9 * * @return bool False when preview short-circuits due no change needing to be previewed. */ public function preview() { if ( $this->is_previewed ) { return false; } $this->is_previewed = true; add_filter( 'wp_get_custom_css', array( $this, 'filter_previewed_wp_get_custom_css' ), 9, 2 ); return true; } /** * Filters `wp_get_custom_css` for applying the customized value. * * This is used in the preview when `wp_get_custom_css()` is called for rendering the styles. * * @since 4.7.0 * * @see wp_get_custom_css() * * @param string $css Original CSS. * @param string $stylesheet Current stylesheet. * @return string CSS. */ public function filter_previewed_wp_get_custom_css( $css, $stylesheet ) { if ( $stylesheet === $this->stylesheet ) { $customized_value = $this->post_value( null ); if ( ! is_null( $customized_value ) ) { $css = $customized_value; } } return $css; } /** * Fetch the value of the setting. Will return the previewed value when `preview()` is called. * * @since 4.7.0 * * @see WP_Customize_Setting::value() * * @return string */ public function value() { if ( $this->is_previewed ) { $post_value = $this->post_value( null ); if ( null !== $post_value ) { return $post_value; } } $id_base = $this->id_data['base']; $value = ''; $post = wp_get_custom_css_post( $this->stylesheet ); if ( $post ) { $value = $post->post_content; } if ( empty( $value ) ) { $value = $this->default; } /** This filter is documented in wp-includes/class-wp-customize-setting.php */ $value = apply_filters( "customize_value_{$id_base}", $value, $this ); return $value; } /** * Validate a received value for being valid CSS. * * Checks for imbalanced braces, brackets, and comments. * Notifications are rendered when the customizer state is saved. * * @since 4.7.0 * @since 4.9.0 Checking for balanced characters has been moved client-side via linting in code editor. * @since 5.9.0 Renamed `$css` to `$value` for PHP 8 named parameter support. * * @param string $value CSS to validate. * @return true|WP_Error True if the input was validated, otherwise WP_Error. */ public function validate( $value ) { // Restores the more descriptive, specific name for use within this method. $css = $value; $validity = new WP_Error(); if ( preg_match( '#add( 'illegal_markup', __( 'Markup is not allowed in CSS.' ) ); } if ( ! $validity->has_errors() ) { $validity = parent::validate( $css ); } return $validity; } /** * Store the CSS setting value in the custom_css custom post type for the stylesheet. * * @since 4.7.0 * @since 5.9.0 Renamed `$css` to `$value` for PHP 8 named parameter support. * * @param string $value CSS to update. * @return int|false The post ID or false if the value could not be saved. */ public function update( $value ) { // Restores the more descriptive, specific name for use within this method. $css = $value; if ( empty( $css ) ) { $css = ''; } $r = wp_update_custom_css_post( $css, array( 'stylesheet' => $this->stylesheet, ) ); if ( is_wp_error( $r ) ) { return false; } $post_id = $r->ID; // Cache post ID in theme mod for performance to avoid additional DB query. if ( $this->manager->get_stylesheet() === $this->stylesheet ) { set_theme_mod( 'custom_css_post_id', $post_id ); } return $post_id; } } class-wp-customize-new-menu-control.php000064400000003256152222507600014244 0ustar00 setting->post_id; return $exported; } } class-wp-customize-theme-control.php000064400000027161152222507600013614 0ustar00json['theme'] = $this->theme; } /** * Don't render the control content from PHP, as it's rendered via JS on load. * * @since 4.2.0 */ public function render_content() {} /** * Render a JS template for theme display. * * @since 4.2.0 */ public function content_template() { /* translators: %s: Theme name. */ $details_label = sprintf( __( 'Details for theme: %s' ), '{{ data.theme.name }}' ); /* translators: %s: Theme name. */ $customize_label = sprintf( __( 'Customize theme: %s' ), '{{ data.theme.name }}' ); /* translators: %s: Theme name. */ $preview_label = sprintf( __( 'Live preview theme: %s' ), '{{ data.theme.name }}' ); /* translators: %s: Theme name. */ $install_label = sprintf( __( 'Install and preview theme: %s' ), '{{ data.theme.name }}' ); ?> <# if ( data.theme.active ) { #>
    <# } else { #>
    <# } #> <# if ( data.theme.screenshot && data.theme.screenshot[0] ) { #>
    <# } else { #>
    <# } #>
    <# if ( 'installed' === data.theme.type && data.theme.hasUpdate ) { #> <# if ( data.theme.updateResponse.compatibleWP && data.theme.updateResponse.compatiblePHP ) { #>

    ' . __( 'Update now' ) . '' ); } ?>

    <# } else { #>

    <# if ( ! data.theme.updateResponse.compatibleWP && ! data.theme.updateResponse.compatiblePHP ) { #> Please update WordPress, and then learn more about updating PHP.' ), self_admin_url( 'update-core.php' ), esc_url( wp_get_update_php_url() ) ); wp_update_php_annotation( '

    ', '' ); } elseif ( current_user_can( 'update_core' ) ) { printf( /* translators: %s: URL to WordPress Updates screen. */ ' ' . __( 'Please update WordPress.' ), self_admin_url( 'update-core.php' ) ); } elseif ( current_user_can( 'update_php' ) ) { printf( /* translators: %s: URL to Update PHP page. */ ' ' . __( 'Learn more about updating PHP.' ), esc_url( wp_get_update_php_url() ) ); wp_update_php_annotation( '

    ', '' ); } ?> <# } else if ( ! data.theme.updateResponse.compatibleWP ) { #> Please update WordPress.' ), self_admin_url( 'update-core.php' ) ); } ?> <# } else if ( ! data.theme.updateResponse.compatiblePHP ) { #> Learn more about updating PHP.' ), esc_url( wp_get_update_php_url() ) ); wp_update_php_annotation( '

    ', '' ); } ?> <# } #>

    <# } #> <# } #> <# if ( ! data.theme.compatibleWP || ! data.theme.compatiblePHP ) { #>

    <# if ( ! data.theme.compatibleWP && ! data.theme.compatiblePHP ) { #> Please update WordPress, and then learn more about updating PHP.' ), self_admin_url( 'update-core.php' ), esc_url( wp_get_update_php_url() ) ); wp_update_php_annotation( '

    ', '' ); } elseif ( current_user_can( 'update_core' ) ) { printf( /* translators: %s: URL to WordPress Updates screen. */ ' ' . __( 'Please update WordPress.' ), self_admin_url( 'update-core.php' ) ); } elseif ( current_user_can( 'update_php' ) ) { printf( /* translators: %s: URL to Update PHP page. */ ' ' . __( 'Learn more about updating PHP.' ), esc_url( wp_get_update_php_url() ) ); wp_update_php_annotation( '

    ', '' ); } ?> <# } else if ( ! data.theme.compatibleWP ) { #> Please update WordPress.' ), self_admin_url( 'update-core.php' ) ); } ?> <# } else if ( ! data.theme.compatiblePHP ) { #> Learn more about updating PHP.' ), esc_url( wp_get_update_php_url() ) ); wp_update_php_annotation( '

    ', '' ); } ?> <# } #>

    <# } #> <# if ( data.theme.active ) { #>

    {{ data.theme.name }}

    'success', 'additional_classes' => array( 'notice-alt' ), ) ); ?> <# } else if ( 'installed' === data.theme.type ) { #> <# if ( data.theme.blockTheme ) { #>

    {{ data.theme.name }}

    <# if ( data.theme.actions.activate ) { #> <# } #>
    <# if ( data.theme.actions.activate ) { #> activate this theme, and use the Site Editor to customize it.' ), '{{{ data.theme.actions.activate }}}' ); ?> <# } #> 'error', 'additional_classes' => array( 'notice-alt' ), ) ); ?> <# } else { #>

    {{ data.theme.name }}

    <# if ( data.theme.compatibleWP && data.theme.compatiblePHP ) { #> <# } else { #> <# } #>
    'success', 'additional_classes' => array( 'notice-alt' ), ) ); ?> <# } #> <# } else { #>

    {{ data.theme.name }}

    <# if ( data.theme.compatibleWP && data.theme.compatiblePHP ) { #> <# } else { #> <# } #>
    <# } #>
    <# var elementId; #> sidebar_id; return $json; } /** * Whether the current sidebar is rendered on the page. * * @since 4.1.0 * * @return bool Whether sidebar is rendered. */ public function active_callback() { return $this->manager->widgets->is_sidebar_rendered( $this->sidebar_id ); } } class-wp-customize-nav-menu-section.php000064400000001314152222507600014214 0ustar00id ); return $exported; } } class-wp-customize-code-editor-control.php000064400000004415152222507600014705 0ustar00editor_settings = wp_enqueue_code_editor( array_merge( array( 'type' => $this->code_type, 'codemirror' => array( 'indentUnit' => 2, 'tabSize' => 2, ), ), $this->editor_settings ) ); } /** * Refresh the parameters passed to the JavaScript via JSON. * * @since 4.9.0 * * @see WP_Customize_Control::json() * * @return array Array of parameters passed to the JavaScript. */ public function json() { $json = parent::json(); $json['editor_settings'] = $this->editor_settings; $json['input_attrs'] = $this->input_attrs; return $json; } /** * Don't render the control content from PHP, as it's rendered via JS on load. * * @since 4.9.0 */ public function render_content() {} /** * Render a JS template for control display. * * @since 4.9.0 */ public function content_template() { ?> <# var elementIdPrefix = 'el' + String( Math.random() ); #> <# if ( data.label ) { #> <# } #> <# if ( data.description ) { #> {{{ data.description }}} <# } #>
  • manager->is_theme_active() ) { echo '' . __( 'Active theme' ) . ' {{ data.title }}'; } else { echo '' . __( 'Previewing theme' ) . ' {{ data.title }}'; } ?>

  • ' . __( 'Themes' ) . '' ); // Separate strings for consistency with other panels. ?> <# if ( data.description ) { #> <# } #>
    <# if ( data.description ) { #>
    {{{ data.description }}}
    <# } #>
  • array( 'label' => __( 'Top Left' ), 'icon' => 'dashicons dashicons-arrow-left-alt', ), 'center top' => array( 'label' => __( 'Top' ), 'icon' => 'dashicons dashicons-arrow-up-alt', ), 'right top' => array( 'label' => __( 'Top Right' ), 'icon' => 'dashicons dashicons-arrow-right-alt', ), ), array( 'left center' => array( 'label' => __( 'Left' ), 'icon' => 'dashicons dashicons-arrow-left-alt', ), 'center center' => array( 'label' => __( 'Center' ), 'icon' => 'background-position-center-icon', ), 'right center' => array( 'label' => __( 'Right' ), 'icon' => 'dashicons dashicons-arrow-right-alt', ), ), array( 'left bottom' => array( 'label' => __( 'Bottom Left' ), 'icon' => 'dashicons dashicons-arrow-left-alt', ), 'center bottom' => array( 'label' => __( 'Bottom' ), 'icon' => 'dashicons dashicons-arrow-down-alt', ), 'right bottom' => array( 'label' => __( 'Bottom Right' ), 'icon' => 'dashicons dashicons-arrow-right-alt', ), ), ); ?> <# if ( data.label ) { #> {{{ data.label }}} <# } #> <# if ( data.description ) { #> {{{ data.description }}} <# } #>
    $input ) : ?>
    -?\d+)\]$/'; const TAXONOMY = 'nav_menu'; const TYPE = 'nav_menu'; /** * Setting type. * * @since 4.3.0 * @var string */ public $type = self::TYPE; /** * Default setting value. * * @since 4.3.0 * @var array * * @see wp_get_nav_menu_object() */ public $default = array( 'name' => '', 'description' => '', 'parent' => 0, 'auto_add' => false, ); /** * Default transport. * * @since 4.3.0 * @var string */ public $transport = 'postMessage'; /** * The term ID represented by this setting instance. * * A negative value represents a placeholder ID for a new menu not yet saved. * * @since 4.3.0 * @var int */ public $term_id; /** * Previous (placeholder) term ID used before creating a new menu. * * This value will be exported to JS via the {@see 'customize_save_response'} filter * so that JavaScript can update the settings to refer to the newly-assigned * term ID. This value is always negative to indicate it does not refer to * a real term. * * @since 4.3.0 * @var int * * @see WP_Customize_Nav_Menu_Setting::update() * @see WP_Customize_Nav_Menu_Setting::amend_customize_save_response() */ public $previous_term_id; /** * Whether or not update() was called. * * @since 4.3.0 * @var bool */ protected $is_updated = false; /** * Status for calling the update method, used in customize_save_response filter. * * See {@see 'customize_save_response'}. * * When status is inserted, the placeholder term ID is stored in `$previous_term_id`. * When status is error, the error is stored in `$update_error`. * * @since 4.3.0 * @var string updated|inserted|deleted|error * * @see WP_Customize_Nav_Menu_Setting::update() * @see WP_Customize_Nav_Menu_Setting::amend_customize_save_response() */ public $update_status; /** * Any error object returned by wp_update_nav_menu_object() when setting is updated. * * @since 4.3.0 * @var WP_Error * * @see WP_Customize_Nav_Menu_Setting::update() * @see WP_Customize_Nav_Menu_Setting::amend_customize_save_response() */ public $update_error; /** * Constructor. * * Any supplied $args override class property defaults. * * @since 4.3.0 * * @throws Exception If $id is not valid for this setting type. * * @param WP_Customize_Manager $manager Customizer bootstrap instance. * @param string $id A specific ID of the setting. * Can be a theme mod or option name. * @param array $args Optional. Setting arguments. */ public function __construct( WP_Customize_Manager $manager, $id, array $args = array() ) { if ( empty( $manager->nav_menus ) ) { throw new Exception( 'Expected WP_Customize_Manager::$nav_menus to be set.' ); } if ( ! preg_match( self::ID_PATTERN, $id, $matches ) ) { throw new Exception( "Illegal widget setting ID: $id" ); } $this->term_id = (int) $matches['id']; parent::__construct( $manager, $id, $args ); } /** * Get the instance data for a given widget setting. * * @since 4.3.0 * * @see wp_get_nav_menu_object() * * @return array Instance data. */ public function value() { if ( $this->is_previewed && get_current_blog_id() === $this->_previewed_blog_id ) { $undefined = new stdClass(); // Symbol. $post_value = $this->post_value( $undefined ); if ( $undefined === $post_value ) { $value = $this->_original_value; } else { $value = $post_value; } } else { $value = false; // Note that a term_id of less than one indicates a nav_menu not yet inserted. if ( $this->term_id > 0 ) { $term = wp_get_nav_menu_object( $this->term_id ); if ( $term ) { $value = wp_array_slice_assoc( (array) $term, array_keys( $this->default ) ); $nav_menu_options = (array) get_option( 'nav_menu_options', array() ); $value['auto_add'] = false; if ( isset( $nav_menu_options['auto_add'] ) && is_array( $nav_menu_options['auto_add'] ) ) { $value['auto_add'] = in_array( $term->term_id, $nav_menu_options['auto_add'], true ); } } } if ( ! is_array( $value ) ) { $value = $this->default; } } return $value; } /** * Handle previewing the setting. * * @since 4.3.0 * @since 4.4.0 Added boolean return value * * @see WP_Customize_Manager::post_value() * * @return bool False if method short-circuited due to no-op. */ public function preview() { if ( $this->is_previewed ) { return false; } $undefined = new stdClass(); $is_placeholder = ( $this->term_id < 0 ); $is_dirty = ( $undefined !== $this->post_value( $undefined ) ); if ( ! $is_placeholder && ! $is_dirty ) { return false; } $this->is_previewed = true; $this->_original_value = $this->value(); $this->_previewed_blog_id = get_current_blog_id(); add_filter( 'wp_get_nav_menus', array( $this, 'filter_wp_get_nav_menus' ), 10, 2 ); add_filter( 'wp_get_nav_menu_object', array( $this, 'filter_wp_get_nav_menu_object' ), 10, 2 ); add_filter( 'default_option_nav_menu_options', array( $this, 'filter_nav_menu_options' ) ); add_filter( 'option_nav_menu_options', array( $this, 'filter_nav_menu_options' ) ); return true; } /** * Filters the wp_get_nav_menus() result to ensure the inserted menu object is included, and the deleted one is removed. * * @since 4.3.0 * * @see wp_get_nav_menus() * * @param WP_Term[] $menus An array of menu objects. * @param array $args An array of arguments used to retrieve menu objects. * @return WP_Term[] Array of menu objects. */ public function filter_wp_get_nav_menus( $menus, $args ) { if ( get_current_blog_id() !== $this->_previewed_blog_id ) { return $menus; } $setting_value = $this->value(); $is_delete = ( false === $setting_value ); $index = -1; // Find the existing menu item's position in the list. foreach ( $menus as $i => $menu ) { if ( (int) $this->term_id === (int) $menu->term_id || (int) $this->previous_term_id === (int) $menu->term_id ) { $index = $i; break; } } if ( $is_delete ) { // Handle deleted menu by removing it from the list. if ( -1 !== $index ) { array_splice( $menus, $index, 1 ); } } else { // Handle menus being updated or inserted. $menu_obj = (object) array_merge( array( 'term_id' => $this->term_id, 'term_taxonomy_id' => $this->term_id, 'slug' => sanitize_title( $setting_value['name'] ), 'count' => 0, 'term_group' => 0, 'taxonomy' => self::TAXONOMY, 'filter' => 'raw', ), $setting_value ); array_splice( $menus, $index, ( -1 === $index ? 0 : 1 ), array( $menu_obj ) ); } // Make sure the menu objects get re-sorted after an update/insert. if ( ! $is_delete && ! empty( $args['orderby'] ) ) { $menus = wp_list_sort( $menus, array( $args['orderby'] => 'ASC', ) ); } // @todo Add support for $args['hide_empty'] === true. return $menus; } /** * Temporary non-closure passing of orderby value to function. * * @since 4.3.0 * @var string * * @see WP_Customize_Nav_Menu_Setting::filter_wp_get_nav_menus() * @see WP_Customize_Nav_Menu_Setting::_sort_menus_by_orderby() */ protected $_current_menus_sort_orderby; /** * Sort menu objects by the class-supplied orderby property. * * This is a workaround for a lack of closures. * * @since 4.3.0 * @deprecated 4.7.0 Use wp_list_sort() * * @param object $menu1 * @param object $menu2 * @return int * * @see WP_Customize_Nav_Menu_Setting::filter_wp_get_nav_menus() */ protected function _sort_menus_by_orderby( $menu1, $menu2 ) { _deprecated_function( __METHOD__, '4.7.0', 'wp_list_sort' ); $key = $this->_current_menus_sort_orderby; return strcmp( $menu1->$key, $menu2->$key ); } /** * Filters the wp_get_nav_menu_object() result to supply the previewed menu object. * * Requesting a nav_menu object by anything but ID is not supported. * * @since 4.3.0 * * @see wp_get_nav_menu_object() * * @param object|null $menu_obj Object returned by wp_get_nav_menu_object(). * @param string $menu_id ID of the nav_menu term. Requests by slug or name will be ignored. * @return object|null */ public function filter_wp_get_nav_menu_object( $menu_obj, $menu_id ) { $ok = ( get_current_blog_id() === $this->_previewed_blog_id && is_int( $menu_id ) && $menu_id === $this->term_id ); if ( ! $ok ) { return $menu_obj; } $setting_value = $this->value(); // Handle deleted menus. if ( false === $setting_value ) { return false; } // Handle sanitization failure by preventing short-circuiting. if ( null === $setting_value ) { return $menu_obj; } $menu_obj = (object) array_merge( array( 'term_id' => $this->term_id, 'term_taxonomy_id' => $this->term_id, 'slug' => sanitize_title( $setting_value['name'] ), 'count' => 0, 'term_group' => 0, 'taxonomy' => self::TAXONOMY, 'filter' => 'raw', ), $setting_value ); return $menu_obj; } /** * Filters the nav_menu_options option to include this menu's auto_add preference. * * @since 4.3.0 * * @param array $nav_menu_options Nav menu options including auto_add. * @return array (Maybe) modified nav menu options. */ public function filter_nav_menu_options( $nav_menu_options ) { if ( get_current_blog_id() !== $this->_previewed_blog_id ) { return $nav_menu_options; } $menu = $this->value(); $nav_menu_options = $this->filter_nav_menu_options_value( $nav_menu_options, $this->term_id, false === $menu ? false : $menu['auto_add'] ); return $nav_menu_options; } /** * Sanitize an input. * * Note that parent::sanitize() erroneously does wp_unslash() on $value, but * we remove that in this override. * * @since 4.3.0 * * @param array $value The menu value to sanitize. * @return array|false|null Null if an input isn't valid. False if it is marked for deletion. * Otherwise the sanitized value. */ public function sanitize( $value ) { // Menu is marked for deletion. if ( false === $value ) { return $value; } // Invalid. if ( ! is_array( $value ) ) { return null; } $default = array( 'name' => '', 'description' => '', 'parent' => 0, 'auto_add' => false, ); $value = array_merge( $default, $value ); $value = wp_array_slice_assoc( $value, array_keys( $default ) ); $value['name'] = trim( esc_html( $value['name'] ) ); // This sanitization code is used in wp-admin/nav-menus.php. $value['description'] = sanitize_text_field( $value['description'] ); $value['parent'] = max( 0, (int) $value['parent'] ); $value['auto_add'] = ! empty( $value['auto_add'] ); if ( '' === $value['name'] ) { $value['name'] = _x( '(unnamed)', 'Missing menu name.' ); } /** This filter is documented in wp-includes/class-wp-customize-setting.php */ return apply_filters( "customize_sanitize_{$this->id}", $value, $this ); } /** * Storage for data to be sent back to client in customize_save_response filter. * * See {@see 'customize_save_response'}. * * @since 4.3.0 * @var array * * @see WP_Customize_Nav_Menu_Setting::amend_customize_save_response() */ protected $_widget_nav_menu_updates = array(); /** * Create/update the nav_menu term for this setting. * * Any created menus will have their assigned term IDs exported to the client * via the {@see 'customize_save_response'} filter. Likewise, any errors will be exported * to the client via the customize_save_response() filter. * * To delete a menu, the client can send false as the value. * * @since 4.3.0 * * @see wp_update_nav_menu_object() * * @param array|false $value { * The value to update. Note that slug cannot be updated via wp_update_nav_menu_object(). * If false, then the menu will be deleted entirely. * * @type string $name The name of the menu to save. * @type string $description The term description. Default empty string. * @type int $parent The id of the parent term. Default 0. * @type bool $auto_add Whether pages will auto_add to this menu. Default false. * } * @return null|void */ protected function update( $value ) { if ( $this->is_updated ) { return; } $this->is_updated = true; $is_placeholder = ( $this->term_id < 0 ); $is_delete = ( false === $value ); add_filter( 'customize_save_response', array( $this, 'amend_customize_save_response' ) ); $auto_add = null; if ( $is_delete ) { // If the current setting term is a placeholder, a delete request is a no-op. if ( $is_placeholder ) { $this->update_status = 'deleted'; } else { $r = wp_delete_nav_menu( $this->term_id ); if ( is_wp_error( $r ) ) { $this->update_status = 'error'; $this->update_error = $r; } else { $this->update_status = 'deleted'; $auto_add = false; } } } else { // Insert or update menu. $menu_data = wp_array_slice_assoc( $value, array( 'description', 'parent' ) ); $menu_data['menu-name'] = $value['name']; $menu_id = $is_placeholder ? 0 : $this->term_id; $r = wp_update_nav_menu_object( $menu_id, wp_slash( $menu_data ) ); $original_name = $menu_data['menu-name']; $name_conflict_suffix = 1; while ( is_wp_error( $r ) && 'menu_exists' === $r->get_error_code() ) { $name_conflict_suffix += 1; /* translators: 1: Original menu name, 2: Duplicate count. */ $menu_data['menu-name'] = sprintf( __( '%1$s (%2$d)' ), $original_name, $name_conflict_suffix ); $r = wp_update_nav_menu_object( $menu_id, wp_slash( $menu_data ) ); } if ( is_wp_error( $r ) ) { $this->update_status = 'error'; $this->update_error = $r; } else { if ( $is_placeholder ) { $this->previous_term_id = $this->term_id; $this->term_id = $r; $this->update_status = 'inserted'; } else { $this->update_status = 'updated'; } $auto_add = $value['auto_add']; } } if ( null !== $auto_add ) { $nav_menu_options = $this->filter_nav_menu_options_value( (array) get_option( 'nav_menu_options', array() ), $this->term_id, $auto_add ); update_option( 'nav_menu_options', $nav_menu_options ); } if ( 'inserted' === $this->update_status ) { // Make sure that new menus assigned to nav menu locations use their new IDs. foreach ( $this->manager->settings() as $setting ) { if ( ! preg_match( '/^nav_menu_locations\[/', $setting->id ) ) { continue; } $post_value = $setting->post_value( null ); if ( ! is_null( $post_value ) && (int) $post_value === $this->previous_term_id ) { $this->manager->set_post_value( $setting->id, $this->term_id ); $setting->save(); } } // Make sure that any nav_menu widgets referencing the placeholder nav menu get updated and sent back to client. foreach ( array_keys( $this->manager->unsanitized_post_values() ) as $setting_id ) { $nav_menu_widget_setting = $this->manager->get_setting( $setting_id ); if ( ! $nav_menu_widget_setting || ! preg_match( '/^widget_nav_menu\[/', $nav_menu_widget_setting->id ) ) { continue; } $widget_instance = $nav_menu_widget_setting->post_value(); // Note that this calls WP_Customize_Widgets::sanitize_widget_instance(). if ( empty( $widget_instance['nav_menu'] ) || (int) $widget_instance['nav_menu'] !== $this->previous_term_id ) { continue; } $widget_instance['nav_menu'] = $this->term_id; $updated_widget_instance = $this->manager->widgets->sanitize_widget_js_instance( $widget_instance ); $this->manager->set_post_value( $nav_menu_widget_setting->id, $updated_widget_instance ); $nav_menu_widget_setting->save(); $this->_widget_nav_menu_updates[ $nav_menu_widget_setting->id ] = $updated_widget_instance; } } } /** * Updates a nav_menu_options array. * * @since 4.3.0 * * @see WP_Customize_Nav_Menu_Setting::filter_nav_menu_options() * @see WP_Customize_Nav_Menu_Setting::update() * * @param array $nav_menu_options Array as returned by get_option( 'nav_menu_options' ). * @param int $menu_id The term ID for the given menu. * @param bool $auto_add Whether to auto-add or not. * @return array (Maybe) modified nav_menu_options array. */ protected function filter_nav_menu_options_value( $nav_menu_options, $menu_id, $auto_add ) { $nav_menu_options = (array) $nav_menu_options; if ( ! isset( $nav_menu_options['auto_add'] ) ) { $nav_menu_options['auto_add'] = array(); } $i = array_search( $menu_id, $nav_menu_options['auto_add'], true ); if ( $auto_add && false === $i ) { array_push( $nav_menu_options['auto_add'], $this->term_id ); } elseif ( ! $auto_add && false !== $i ) { array_splice( $nav_menu_options['auto_add'], $i, 1 ); } return $nav_menu_options; } /** * Export data for the JS client. * * @since 4.3.0 * * @see WP_Customize_Nav_Menu_Setting::update() * * @param array $data Additional information passed back to the 'saved' event on `wp.customize`. * @return array Export data. */ public function amend_customize_save_response( $data ) { if ( ! isset( $data['nav_menu_updates'] ) ) { $data['nav_menu_updates'] = array(); } if ( ! isset( $data['widget_nav_menu_updates'] ) ) { $data['widget_nav_menu_updates'] = array(); } $data['nav_menu_updates'][] = array( 'term_id' => $this->term_id, 'previous_term_id' => $this->previous_term_id, 'error' => $this->update_error ? $this->update_error->get_error_code() : null, 'status' => $this->update_status, 'saved_value' => 'deleted' === $this->update_status ? null : $this->value(), ); $data['widget_nav_menu_updates'] = array_merge( $data['widget_nav_menu_updates'], $this->_widget_nav_menu_updates ); $this->_widget_nav_menu_updates = array(); return $data; } } class-wp-customize-selective-refresh.php000064400000033023152222507600014445 0ustar00manager = $manager; require_once ABSPATH . WPINC . '/customize/class-wp-customize-partial.php'; add_action( 'customize_preview_init', array( $this, 'init_preview' ) ); } /** * Retrieves the registered partials. * * @since 4.5.0 * * @return array Partials. */ public function partials() { return $this->partials; } /** * Adds a partial. * * @since 4.5.0 * * @see WP_Customize_Partial::__construct() * * @param WP_Customize_Partial|string $id Customize Partial object, or Partial ID. * @param array $args Optional. Array of properties for the new Partials object. * See WP_Customize_Partial::__construct() for information * on accepted arguments. Default empty array. * @return WP_Customize_Partial The instance of the partial that was added. */ public function add_partial( $id, $args = array() ) { if ( $id instanceof WP_Customize_Partial ) { $partial = $id; } else { $class = 'WP_Customize_Partial'; /** This filter is documented in wp-includes/customize/class-wp-customize-selective-refresh.php */ $args = apply_filters( 'customize_dynamic_partial_args', $args, $id ); /** This filter is documented in wp-includes/customize/class-wp-customize-selective-refresh.php */ $class = apply_filters( 'customize_dynamic_partial_class', $class, $id, $args ); $partial = new $class( $this, $id, $args ); } $this->partials[ $partial->id ] = $partial; return $partial; } /** * Retrieves a partial. * * @since 4.5.0 * * @param string $id Customize Partial ID. * @return WP_Customize_Partial|null The partial, if set. Otherwise null. */ public function get_partial( $id ) { if ( isset( $this->partials[ $id ] ) ) { return $this->partials[ $id ]; } else { return null; } } /** * Removes a partial. * * @since 4.5.0 * * @param string $id Customize Partial ID. */ public function remove_partial( $id ) { unset( $this->partials[ $id ] ); } /** * Initializes the Customizer preview. * * @since 4.5.0 */ public function init_preview() { add_action( 'template_redirect', array( $this, 'handle_render_partials_request' ) ); add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_preview_scripts' ) ); } /** * Enqueues preview scripts. * * @since 4.5.0 */ public function enqueue_preview_scripts() { wp_enqueue_script( 'customize-selective-refresh' ); add_action( 'wp_footer', array( $this, 'export_preview_data' ), 1000 ); } /** * Exports data in preview after it has finished rendering so that partials can be added at runtime. * * @since 4.5.0 */ public function export_preview_data() { $partials = array(); foreach ( $this->partials() as $partial ) { if ( $partial->check_capabilities() ) { $partials[ $partial->id ] = $partial->json(); } } $switched_locale = switch_to_user_locale( get_current_user_id() ); $l10n = array( 'shiftClickToEdit' => __( 'Shift-click to edit this element.' ), 'clickEditMenu' => __( 'Click to edit this menu.' ), 'clickEditWidget' => __( 'Click to edit this widget.' ), 'clickEditTitle' => __( 'Click to edit the site title.' ), 'clickEditMisc' => __( 'Click to edit this element.' ), /* translators: %s: document.write() */ 'badDocumentWrite' => sprintf( __( '%s is forbidden' ), 'document.write()' ), ); if ( $switched_locale ) { restore_previous_locale(); } $exports = array( 'partials' => $partials, 'renderQueryVar' => self::RENDER_QUERY_VAR, 'l10n' => $l10n, ); // Export data to JS. wp_print_inline_script_tag( sprintf( 'var _customizePartialRefreshExports = %s;', wp_json_encode( $exports, JSON_HEX_TAG | JSON_UNESCAPED_SLASHES ) ) . "\n//# sourceURL=" . rawurlencode( __METHOD__ ) ); } /** * Registers dynamically-created partials. * * @since 4.5.0 * * @see WP_Customize_Manager::add_dynamic_settings() * * @param string[] $partial_ids Array of the partial IDs to add. * @return WP_Customize_Partial[] Array of added WP_Customize_Partial instances. */ public function add_dynamic_partials( $partial_ids ) { $new_partials = array(); foreach ( $partial_ids as $partial_id ) { // Skip partials already created. $partial = $this->get_partial( $partial_id ); if ( $partial ) { continue; } $partial_args = false; $partial_class = 'WP_Customize_Partial'; /** * Filters a dynamic partial's constructor arguments. * * For a dynamic partial to be registered, this filter must be employed * to override the default false value with an array of args to pass to * the WP_Customize_Partial constructor. * * @since 4.5.0 * * @param false|array $partial_args The arguments to the WP_Customize_Partial constructor. * @param string $partial_id ID for dynamic partial. */ $partial_args = apply_filters( 'customize_dynamic_partial_args', $partial_args, $partial_id ); if ( false === $partial_args ) { continue; } /** * Filters the class used to construct partials. * * Allow non-statically created partials to be constructed with custom WP_Customize_Partial subclass. * * @since 4.5.0 * * @param string $partial_class WP_Customize_Partial or a subclass. * @param string $partial_id ID for dynamic partial. * @param array $partial_args The arguments to the WP_Customize_Partial constructor. */ $partial_class = apply_filters( 'customize_dynamic_partial_class', $partial_class, $partial_id, $partial_args ); $partial = new $partial_class( $this, $partial_id, $partial_args ); $this->add_partial( $partial ); $new_partials[] = $partial; } return $new_partials; } /** * Checks whether the request is for rendering partials. * * Note that this will not consider whether the request is authorized or valid, * just that essentially the route is a match. * * @since 4.5.0 * * @return bool Whether the request is for rendering partials. */ public function is_render_partials_request() { return ! empty( $_POST[ self::RENDER_QUERY_VAR ] ); } /** * Handles PHP errors triggered during rendering the partials. * * These errors will be relayed back to the client in the Ajax response. * * @since 4.5.0 * * @param int $errno Error number. * @param string $errstr Error string. * @param string $errfile Error file. * @param int $errline Error line. * @return true Always true. */ public function handle_error( $errno, $errstr, $errfile = null, $errline = null ) { $this->triggered_errors[] = array( 'partial' => $this->current_partial_id, 'error_number' => $errno, 'error_string' => $errstr, 'error_file' => $errfile, 'error_line' => $errline, ); return true; } /** * Handles the Ajax request to return the rendered partials for the requested placements. * * @since 4.5.0 */ public function handle_render_partials_request() { if ( ! $this->is_render_partials_request() ) { return; } /* * Note that is_customize_preview() returning true will entail that the * user passed the 'customize' capability check and the nonce check, since * WP_Customize_Manager::setup_theme() is where the previewing flag is set. */ if ( ! is_customize_preview() ) { wp_send_json_error( 'expected_customize_preview', 403 ); } elseif ( ! isset( $_POST['partials'] ) ) { wp_send_json_error( 'missing_partials', 400 ); } // Ensure that doing selective refresh on 404 template doesn't result in fallback rendering behavior (full refreshes). status_header( 200 ); $partials = json_decode( wp_unslash( $_POST['partials'] ), true ); if ( ! is_array( $partials ) ) { wp_send_json_error( 'malformed_partials' ); } $this->add_dynamic_partials( array_keys( $partials ) ); /** * Fires immediately before partials are rendered. * * Plugins may do things like call wp_enqueue_scripts() and gather a list of the scripts * and styles which may get enqueued in the response. * * @since 4.5.0 * * @param WP_Customize_Selective_Refresh $refresh Selective refresh component. * @param array $partials Placements' context data for the partials rendered in the request. * The array is keyed by partial ID, with each item being an array of * the placements' context data. */ do_action( 'customize_render_partials_before', $this, $partials ); set_error_handler( array( $this, 'handle_error' ), error_reporting() ); $contents = array(); foreach ( $partials as $partial_id => $container_contexts ) { $this->current_partial_id = $partial_id; if ( ! is_array( $container_contexts ) ) { wp_send_json_error( 'malformed_container_contexts' ); } $partial = $this->get_partial( $partial_id ); if ( ! $partial || ! $partial->check_capabilities() ) { $contents[ $partial_id ] = null; continue; } $contents[ $partial_id ] = array(); // @todo The array should include not only the contents, but also whether the container is included? if ( empty( $container_contexts ) ) { // Since there are no container contexts, render just once. $contents[ $partial_id ][] = $partial->render( null ); } else { foreach ( $container_contexts as $container_context ) { $contents[ $partial_id ][] = $partial->render( $container_context ); } } } $this->current_partial_id = null; restore_error_handler(); /** * Fires immediately after partials are rendered. * * Plugins may do things like call wp_footer() to scrape scripts output and return them * via the {@see 'customize_render_partials_response'} filter. * * @since 4.5.0 * * @param WP_Customize_Selective_Refresh $refresh Selective refresh component. * @param array $partials Placements' context data for the partials rendered in the request. * The array is keyed by partial ID, with each item being an array of * the placements' context data. */ do_action( 'customize_render_partials_after', $this, $partials ); $response = array( 'contents' => $contents, ); if ( defined( 'WP_DEBUG_DISPLAY' ) && WP_DEBUG_DISPLAY ) { $response['errors'] = $this->triggered_errors; } $setting_validities = $this->manager->validate_setting_values( $this->manager->unsanitized_post_values() ); $exported_setting_validities = array_map( array( $this->manager, 'prepare_setting_validity_for_js' ), $setting_validities ); $response['setting_validities'] = $exported_setting_validities; /** * Filters the response from rendering the partials. * * Plugins may use this filter to inject `$scripts` and `$styles`, which are dependencies * for the partials being rendered. The response data will be available to the client via * the `render-partials-response` JS event, so the client can then inject the scripts and * styles into the DOM if they have not already been enqueued there. * * If plugins do this, they'll need to take care for any scripts that do `document.write()` * and make sure that these are not injected, or else to override the function to no-op, * or else the page will be destroyed. * * Plugins should be aware that `$scripts` and `$styles` may eventually be included by * default in the response. * * @since 4.5.0 * * @param array $response { * Response. * * @type array $contents Associative array mapping a partial ID its corresponding array of contents * for the containers requested. * @type array $errors List of errors triggered during rendering of partials, if `WP_DEBUG_DISPLAY` * is enabled. * } * @param WP_Customize_Selective_Refresh $refresh Selective refresh component. * @param array $partials Placements' context data for the partials rendered in the request. * The array is keyed by partial ID, with each item being an array of * the placements' context data. */ $response = apply_filters( 'customize_render_partials_response', $response, $this, $partials ); wp_send_json_success( $response ); } } class-wp-widget-form-customize-control.php000064400000005126152222507600014733 0ustar00json[ $key ] = $this->$key; } // Get the widget_control and widget_content. require_once ABSPATH . 'wp-admin/includes/widgets.php'; $widget = $wp_registered_widgets[ $this->widget_id ]; if ( ! isset( $widget['params'][0] ) ) { $widget['params'][0] = array(); } $args = array( 'widget_id' => $widget['id'], 'widget_name' => $widget['name'], ); $args = wp_list_widget_controls_dynamic_sidebar( array( 0 => $args, 1 => $widget['params'][0], ) ); $widget_control_parts = $this->manager->widgets->get_widget_control_parts( $args ); $this->json['widget_control'] = $widget_control_parts['control']; $this->json['widget_content'] = $widget_control_parts['content']; } /** * Override render_content to be no-op since content is exported via to_json for deferred embedding. * * @since 3.9.0 */ public function render_content() {} /** * Whether the current widget is rendered on the page. * * @since 4.0.0 * * @return bool Whether the widget is rendered. */ public function active_callback() { return $this->manager->widgets->is_widget_rendered( $this->widget_id ); } } class-wp-customize-upload-control.php000064400000002255152222507600013773 0ustar00value(); if ( $value ) { // Get the attachment model for the existing file. $attachment_id = attachment_url_to_postid( $value ); if ( $attachment_id ) { $this->json['attachment'] = wp_prepare_attachment_for_js( $attachment_id ); } } } } class-wp-customize-nav-menu-item-setting.php000064400000066335152222507600015177 0ustar00-?\d+)\]$/'; const POST_TYPE = 'nav_menu_item'; const TYPE = 'nav_menu_item'; /** * Setting type. * * @since 4.3.0 * @var string */ public $type = self::TYPE; /** * Default setting value. * * @since 4.3.0 * @var array * * @see wp_setup_nav_menu_item() */ public $default = array( // The $menu_item_data for wp_update_nav_menu_item(). 'object_id' => 0, 'object' => '', // Taxonomy name. 'menu_item_parent' => 0, // A.K.A. menu-item-parent-id; note that post_parent is different, and not included. 'position' => 0, // A.K.A. menu_order. 'type' => 'custom', // Note that type_label is not included here. 'title' => '', 'url' => '', 'target' => '', 'attr_title' => '', 'description' => '', 'classes' => '', 'xfn' => '', 'status' => 'publish', 'nav_menu_term_id' => 0, // This will be supplied as the $menu_id arg for wp_update_nav_menu_item(). '_invalid' => false, ); /** * Default transport. * * @since 4.3.0 * @since 4.5.0 Default changed to 'refresh' * @var string */ public $transport = 'refresh'; /** * The post ID represented by this setting instance. This is the db_id. * * A negative value represents a placeholder ID for a new menu not yet saved. * * @since 4.3.0 * @var int */ public $post_id; /** * Storage of pre-setup menu item to prevent wasted calls to wp_setup_nav_menu_item(). * * @since 4.3.0 * @var array|null */ protected $value; /** * Previous (placeholder) post ID used before creating a new menu item. * * This value will be exported to JS via the customize_save_response filter * so that JavaScript can update the settings to refer to the newly-assigned * post ID. This value is always negative to indicate it does not refer to * a real post. * * @since 4.3.0 * @var int * * @see WP_Customize_Nav_Menu_Item_Setting::update() * @see WP_Customize_Nav_Menu_Item_Setting::amend_customize_save_response() */ public $previous_post_id; /** * When previewing or updating a menu item, this stores the previous nav_menu_term_id * which ensures that we can apply the proper filters. * * @since 4.3.0 * @var int */ public $original_nav_menu_term_id; /** * Whether or not update() was called. * * @since 4.3.0 * @var bool */ protected $is_updated = false; /** * Status for calling the update method, used in customize_save_response filter. * * See {@see 'customize_save_response'}. * * When status is inserted, the placeholder post ID is stored in $previous_post_id. * When status is error, the error is stored in $update_error. * * @since 4.3.0 * @var string updated|inserted|deleted|error * * @see WP_Customize_Nav_Menu_Item_Setting::update() * @see WP_Customize_Nav_Menu_Item_Setting::amend_customize_save_response() */ public $update_status; /** * Any error object returned by wp_update_nav_menu_item() when setting is updated. * * @since 4.3.0 * @var WP_Error * * @see WP_Customize_Nav_Menu_Item_Setting::update() * @see WP_Customize_Nav_Menu_Item_Setting::amend_customize_save_response() */ public $update_error; /** * Constructor. * * Any supplied $args override class property defaults. * * @since 4.3.0 * * @throws Exception If $id is not valid for this setting type. * * @param WP_Customize_Manager $manager Customizer bootstrap instance. * @param string $id A specific ID of the setting. * Can be a theme mod or option name. * @param array $args Optional. Setting arguments. */ public function __construct( WP_Customize_Manager $manager, $id, array $args = array() ) { if ( empty( $manager->nav_menus ) ) { throw new Exception( 'Expected WP_Customize_Manager::$nav_menus to be set.' ); } if ( ! preg_match( self::ID_PATTERN, $id, $matches ) ) { throw new Exception( "Illegal widget setting ID: $id" ); } $this->post_id = (int) $matches['id']; add_action( 'wp_update_nav_menu_item', array( $this, 'flush_cached_value' ), 10, 2 ); parent::__construct( $manager, $id, $args ); // Ensure that an initially-supplied value is valid. if ( isset( $this->value ) ) { $this->populate_value(); foreach ( array_diff( array_keys( $this->default ), array_keys( $this->value ) ) as $missing ) { throw new Exception( "Supplied nav_menu_item value missing property: $missing" ); } } } /** * Clear the cached value when this nav menu item is updated. * * @since 4.3.0 * * @param int $menu_id The term ID for the menu. * @param int $menu_item_id The post ID for the menu item. */ public function flush_cached_value( $menu_id, $menu_item_id ) { unset( $menu_id ); if ( $menu_item_id === $this->post_id ) { $this->value = null; } } /** * Get the instance data for a given nav_menu_item setting. * * @since 4.3.0 * * @see wp_setup_nav_menu_item() * * @return array|false Instance data array, or false if the item is marked for deletion. */ public function value() { $type_label = null; if ( $this->is_previewed && get_current_blog_id() === $this->_previewed_blog_id ) { $undefined = new stdClass(); // Symbol. $post_value = $this->post_value( $undefined ); if ( $undefined === $post_value ) { $value = $this->_original_value; } else { $value = $post_value; } } elseif ( isset( $this->value ) ) { $value = $this->value; } else { $value = false; // Note that an ID of less than one indicates a nav_menu not yet inserted. if ( $this->post_id > 0 ) { $post = get_post( $this->post_id ); if ( $post && self::POST_TYPE === $post->post_type ) { $is_title_empty = empty( $post->post_title ); $value = (array) wp_setup_nav_menu_item( $post ); if ( isset( $value['type_label'] ) ) { $type_label = $value['type_label']; } if ( $is_title_empty ) { $value['title'] = ''; } } } if ( ! is_array( $value ) ) { $value = $this->default; } // Cache the value for future calls to avoid having to re-call wp_setup_nav_menu_item(). $this->value = $value; $this->populate_value(); $value = $this->value; } // These properties are read-only and are part of the setting for use in the Customizer UI. if ( is_array( $value ) ) { $value_obj = (object) $value; $value['type_label'] = isset( $type_label ) ? $type_label : $this->get_type_label( $value_obj ); $value['original_title'] = $this->get_original_title( $value_obj ); } return $value; } /** * Prepares the value for editing on the client. * * @since 6.8.3 * * @return array|false Value prepared for the client. */ public function js_value() { $value = parent::js_value(); if ( is_array( $value ) && isset( $value['original_title'] ) ) { // Decode entities for the sake of displaying the original title as a placeholder. $value['original_title'] = html_entity_decode( $value['original_title'], ENT_QUOTES, get_bloginfo( 'charset' ) ); } return $value; } /** * Get original title. * * @since 4.7.0 * * @param object $item Nav menu item. * @return string The original title, without entity decoding. */ protected function get_original_title( $item ) { $original_title = ''; if ( 'post_type' === $item->type && ! empty( $item->object_id ) ) { $original_object = get_post( $item->object_id ); if ( $original_object ) { /** This filter is documented in wp-includes/post-template.php */ $original_title = apply_filters( 'the_title', $original_object->post_title, $original_object->ID ); if ( '' === $original_title ) { /* translators: %d: ID of a post. */ $original_title = sprintf( __( '#%d (no title)' ), $original_object->ID ); } } } elseif ( 'taxonomy' === $item->type && ! empty( $item->object_id ) ) { $original_term_title = get_term_field( 'name', $item->object_id, $item->object, 'raw' ); if ( ! is_wp_error( $original_term_title ) ) { $original_title = $original_term_title; } } elseif ( 'post_type_archive' === $item->type ) { $original_object = get_post_type_object( $item->object ); if ( $original_object ) { $original_title = $original_object->labels->archives; } } return $original_title; } /** * Get type label. * * @since 4.7.0 * * @param object $item Nav menu item. * @return string The type label. */ protected function get_type_label( $item ) { if ( 'post_type' === $item->type ) { $object = get_post_type_object( $item->object ); if ( $object ) { $type_label = $object->labels->singular_name; } else { $type_label = $item->object; } } elseif ( 'taxonomy' === $item->type ) { $object = get_taxonomy( $item->object ); if ( $object ) { $type_label = $object->labels->singular_name; } else { $type_label = $item->object; } } elseif ( 'post_type_archive' === $item->type ) { $type_label = __( 'Post Type Archive' ); } else { $type_label = __( 'Custom Link' ); } return $type_label; } /** * Ensure that the value is fully populated with the necessary properties. * * Translates some properties added by wp_setup_nav_menu_item() and removes others. * * @since 4.3.0 * * @see WP_Customize_Nav_Menu_Item_Setting::value() */ protected function populate_value() { if ( ! is_array( $this->value ) ) { return; } if ( isset( $this->value['menu_order'] ) ) { $this->value['position'] = $this->value['menu_order']; unset( $this->value['menu_order'] ); } if ( isset( $this->value['post_status'] ) ) { $this->value['status'] = $this->value['post_status']; unset( $this->value['post_status'] ); } if ( ! isset( $this->value['nav_menu_term_id'] ) && $this->post_id > 0 ) { $menus = wp_get_post_terms( $this->post_id, WP_Customize_Nav_Menu_Setting::TAXONOMY, array( 'fields' => 'ids', ) ); if ( ! empty( $menus ) ) { $this->value['nav_menu_term_id'] = array_shift( $menus ); } else { $this->value['nav_menu_term_id'] = 0; } } foreach ( array( 'object_id', 'menu_item_parent', 'nav_menu_term_id' ) as $key ) { if ( ! is_int( $this->value[ $key ] ) ) { $this->value[ $key ] = (int) $this->value[ $key ]; } } foreach ( array( 'classes', 'xfn' ) as $key ) { if ( is_array( $this->value[ $key ] ) ) { $this->value[ $key ] = implode( ' ', $this->value[ $key ] ); } } if ( ! isset( $this->value['title'] ) ) { $this->value['title'] = ''; } if ( ! isset( $this->value['_invalid'] ) ) { $this->value['_invalid'] = false; $is_known_invalid = ( ( ( 'post_type' === $this->value['type'] || 'post_type_archive' === $this->value['type'] ) && ! post_type_exists( $this->value['object'] ) ) || ( 'taxonomy' === $this->value['type'] && ! taxonomy_exists( $this->value['object'] ) ) ); if ( $is_known_invalid ) { $this->value['_invalid'] = true; } } // Remove remaining properties available on a setup nav_menu_item post object which aren't relevant to the setting value. $irrelevant_properties = array( 'ID', 'comment_count', 'comment_status', 'db_id', 'filter', 'guid', 'ping_status', 'pinged', 'post_author', 'post_content', 'post_content_filtered', 'post_date', 'post_date_gmt', 'post_excerpt', 'post_mime_type', 'post_modified', 'post_modified_gmt', 'post_name', 'post_parent', 'post_password', 'post_title', 'post_type', 'to_ping', ); foreach ( $irrelevant_properties as $property ) { unset( $this->value[ $property ] ); } } /** * Handle previewing the setting. * * @since 4.3.0 * @since 4.4.0 Added boolean return value. * * @see WP_Customize_Manager::post_value() * * @return bool False if method short-circuited due to no-op. */ public function preview() { if ( $this->is_previewed ) { return false; } $undefined = new stdClass(); $is_placeholder = ( $this->post_id < 0 ); $is_dirty = ( $undefined !== $this->post_value( $undefined ) ); if ( ! $is_placeholder && ! $is_dirty ) { return false; } $this->is_previewed = true; $this->_original_value = $this->value(); $this->original_nav_menu_term_id = $this->_original_value['nav_menu_term_id']; $this->_previewed_blog_id = get_current_blog_id(); add_filter( 'wp_get_nav_menu_items', array( $this, 'filter_wp_get_nav_menu_items' ), 10, 3 ); $sort_callback = array( __CLASS__, 'sort_wp_get_nav_menu_items' ); if ( ! has_filter( 'wp_get_nav_menu_items', $sort_callback ) ) { add_filter( 'wp_get_nav_menu_items', array( __CLASS__, 'sort_wp_get_nav_menu_items' ), 1000, 3 ); } // @todo Add get_post_metadata filters for plugins to add their data. return true; } /** * Filters the wp_get_nav_menu_items() result to supply the previewed menu items. * * @since 4.3.0 * * @see wp_get_nav_menu_items() * * @param WP_Post[] $items An array of menu item post objects. * @param WP_Term $menu The menu object. * @param array $args An array of arguments used to retrieve menu item objects. * @return WP_Post[] Array of menu item objects. */ public function filter_wp_get_nav_menu_items( $items, $menu, $args ) { $this_item = $this->value(); $current_nav_menu_term_id = null; if ( isset( $this_item['nav_menu_term_id'] ) ) { $current_nav_menu_term_id = $this_item['nav_menu_term_id']; unset( $this_item['nav_menu_term_id'] ); } $should_filter = ( $menu->term_id === $this->original_nav_menu_term_id || $menu->term_id === $current_nav_menu_term_id ); if ( ! $should_filter ) { return $items; } // Handle deleted menu item, or menu item moved to another menu. $should_remove = ( false === $this_item || ( isset( $this_item['_invalid'] ) && true === $this_item['_invalid'] ) || ( $this->original_nav_menu_term_id === $menu->term_id && $current_nav_menu_term_id !== $this->original_nav_menu_term_id ) ); if ( $should_remove ) { $filtered_items = array(); foreach ( $items as $item ) { if ( $item->db_id !== $this->post_id ) { $filtered_items[] = $item; } } return $filtered_items; } $mutated = false; $should_update = ( is_array( $this_item ) && $current_nav_menu_term_id === $menu->term_id ); if ( $should_update ) { foreach ( $items as $item ) { if ( $item->db_id === $this->post_id ) { foreach ( get_object_vars( $this->value_as_wp_post_nav_menu_item() ) as $key => $value ) { $item->$key = $value; } $mutated = true; } } // Not found so we have to append it.. if ( ! $mutated ) { $items[] = $this->value_as_wp_post_nav_menu_item(); } } return $items; } /** * Re-apply the tail logic also applied on $items by wp_get_nav_menu_items(). * * @since 4.3.0 * * @see wp_get_nav_menu_items() * * @param WP_Post[] $items An array of menu item post objects. * @param WP_Term $menu The menu object. * @param array $args An array of arguments used to retrieve menu item objects. * @return WP_Post[] Array of menu item objects. */ public static function sort_wp_get_nav_menu_items( $items, $menu, $args ) { // @todo We should probably re-apply some constraints imposed by $args. unset( $args['include'] ); // Remove invalid items only in front end. if ( ! is_admin() ) { $items = array_filter( $items, '_is_valid_nav_menu_item' ); } if ( ARRAY_A === $args['output'] ) { $items = wp_list_sort( $items, array( $args['output_key'] => 'ASC', ) ); $i = 1; foreach ( $items as $k => $item ) { $items[ $k ]->{$args['output_key']} = $i++; } } return $items; } /** * Get the value emulated into a WP_Post and set up as a nav_menu_item. * * @since 4.3.0 * * @return WP_Post With wp_setup_nav_menu_item() applied. */ public function value_as_wp_post_nav_menu_item() { $item = (object) $this->value(); unset( $item->nav_menu_term_id ); $item->post_status = $item->status; unset( $item->status ); $item->post_type = 'nav_menu_item'; $item->menu_order = $item->position; unset( $item->position ); if ( empty( $item->title ) && ! empty( $item->original_title ) ) { $item->title = $item->original_title; // This is NOT entity-decoded. It comes from self::get_original_title(). } if ( $item->title ) { $item->post_title = $item->title; } // 'classes' should be an array, as in wp_setup_nav_menu_item(). if ( isset( $item->classes ) && is_scalar( $item->classes ) ) { $item->classes = explode( ' ', $item->classes ); } $item->ID = $this->post_id; $item->db_id = $this->post_id; $post = new WP_Post( (object) $item ); if ( empty( $post->post_author ) ) { $post->post_author = get_current_user_id(); } if ( ! isset( $post->type_label ) ) { $post->type_label = $this->get_type_label( $post ); } // Ensure nav menu item URL is set according to linked object. if ( 'post_type' === $post->type && ! empty( $post->object_id ) ) { $post->url = get_permalink( $post->object_id ); } elseif ( 'taxonomy' === $post->type && ! empty( $post->object ) && ! empty( $post->object_id ) ) { $post->url = get_term_link( (int) $post->object_id, $post->object ); } elseif ( 'post_type_archive' === $post->type && ! empty( $post->object ) ) { $post->url = get_post_type_archive_link( $post->object ); } if ( is_wp_error( $post->url ) ) { $post->url = ''; } /** This filter is documented in wp-includes/nav-menu.php */ $post->attr_title = apply_filters( 'nav_menu_attr_title', $post->attr_title ); /** This filter is documented in wp-includes/nav-menu.php */ $post->description = apply_filters( 'nav_menu_description', wp_trim_words( $post->description, 200 ) ); /** This filter is documented in wp-includes/nav-menu.php */ $post = apply_filters( 'wp_setup_nav_menu_item', $post ); return $post; } /** * Sanitize an input. * * Note that parent::sanitize() erroneously does wp_unslash() on $value, but * we remove that in this override. * * @since 4.3.0 * @since 5.9.0 Renamed `$menu_item_value` to `$value` for PHP 8 named parameter support. * * @param array|false $value The menu item value to sanitize. * @return array|false|null|WP_Error Null or WP_Error if an input isn't valid. False if it is marked for deletion. * Otherwise the sanitized value. */ public function sanitize( $value ) { // Restores the more descriptive, specific name for use within this method. $menu_item_value = $value; // Menu is marked for deletion. if ( false === $menu_item_value ) { return $menu_item_value; } // Invalid. if ( ! is_array( $menu_item_value ) ) { return null; } $default = array( 'object_id' => 0, 'object' => '', 'menu_item_parent' => 0, 'position' => 0, 'type' => 'custom', 'title' => '', 'url' => '', 'target' => '', 'attr_title' => '', 'description' => '', 'classes' => '', 'xfn' => '', 'status' => 'publish', 'original_title' => '', 'nav_menu_term_id' => 0, '_invalid' => false, ); $menu_item_value = array_merge( $default, $menu_item_value ); $menu_item_value = wp_array_slice_assoc( $menu_item_value, array_keys( $default ) ); $menu_item_value['position'] = (int) $menu_item_value['position']; foreach ( array( 'object_id', 'menu_item_parent', 'nav_menu_term_id' ) as $key ) { // Note we need to allow negative-integer IDs for previewed objects not inserted yet. $menu_item_value[ $key ] = (int) $menu_item_value[ $key ]; } foreach ( array( 'type', 'object', 'target' ) as $key ) { $menu_item_value[ $key ] = sanitize_key( $menu_item_value[ $key ] ); } foreach ( array( 'xfn', 'classes' ) as $key ) { $value = $menu_item_value[ $key ]; if ( ! is_array( $value ) ) { $value = explode( ' ', $value ); } $menu_item_value[ $key ] = implode( ' ', array_map( 'sanitize_html_class', $value ) ); } // Apply the same filters as when calling wp_insert_post(). /** This filter is documented in wp-includes/post.php */ $menu_item_value['title'] = wp_unslash( apply_filters( 'title_save_pre', wp_slash( $menu_item_value['title'] ) ) ); /** This filter is documented in wp-includes/post.php */ $menu_item_value['attr_title'] = wp_unslash( apply_filters( 'excerpt_save_pre', wp_slash( $menu_item_value['attr_title'] ) ) ); /** This filter is documented in wp-includes/post.php */ $menu_item_value['description'] = wp_unslash( apply_filters( 'content_save_pre', wp_slash( $menu_item_value['description'] ) ) ); if ( '' !== $menu_item_value['url'] ) { $menu_item_value['url'] = sanitize_url( $menu_item_value['url'] ); if ( '' === $menu_item_value['url'] ) { return new WP_Error( 'invalid_url', __( 'Invalid URL.' ) ); // Fail sanitization if URL is invalid. } } if ( 'publish' !== $menu_item_value['status'] ) { $menu_item_value['status'] = 'draft'; } $menu_item_value['_invalid'] = (bool) $menu_item_value['_invalid']; /** This filter is documented in wp-includes/class-wp-customize-setting.php */ return apply_filters( "customize_sanitize_{$this->id}", $menu_item_value, $this ); } /** * Creates/updates the nav_menu_item post for this setting. * * Any created menu items will have their assigned post IDs exported to the client * via the {@see 'customize_save_response'} filter. Likewise, any errors will be * exported to the client via the customize_save_response() filter. * * To delete a menu, the client can send false as the value. * * @since 4.3.0 * * @see wp_update_nav_menu_item() * * @param array|false $value The menu item array to update. If false, then the menu item will be deleted * entirely. See WP_Customize_Nav_Menu_Item_Setting::$default for what the value * should consist of. * @return null|void */ protected function update( $value ) { if ( $this->is_updated ) { return; } $this->is_updated = true; $is_placeholder = ( $this->post_id < 0 ); $is_delete = ( false === $value ); // Update the cached value. $this->value = $value; add_filter( 'customize_save_response', array( $this, 'amend_customize_save_response' ) ); if ( $is_delete ) { // If the current setting post is a placeholder, a delete request is a no-op. if ( $is_placeholder ) { $this->update_status = 'deleted'; } else { $r = wp_delete_post( $this->post_id, true ); if ( false === $r ) { $this->update_error = new WP_Error( 'delete_failure' ); $this->update_status = 'error'; } else { $this->update_status = 'deleted'; } // @todo send back the IDs for all associated nav menu items deleted, so these settings (and controls) can be removed from Customizer? } } else { // Handle saving menu items for menus that are being newly-created. if ( $value['nav_menu_term_id'] < 0 ) { $nav_menu_setting_id = sprintf( 'nav_menu[%s]', $value['nav_menu_term_id'] ); $nav_menu_setting = $this->manager->get_setting( $nav_menu_setting_id ); if ( ! $nav_menu_setting || ! ( $nav_menu_setting instanceof WP_Customize_Nav_Menu_Setting ) ) { $this->update_status = 'error'; $this->update_error = new WP_Error( 'unexpected_nav_menu_setting' ); return; } if ( false === $nav_menu_setting->save() ) { $this->update_status = 'error'; $this->update_error = new WP_Error( 'nav_menu_setting_failure' ); return; } if ( (int) $value['nav_menu_term_id'] !== $nav_menu_setting->previous_term_id ) { $this->update_status = 'error'; $this->update_error = new WP_Error( 'unexpected_previous_term_id' ); return; } $value['nav_menu_term_id'] = $nav_menu_setting->term_id; } // Handle saving a nav menu item that is a child of a nav menu item being newly-created. if ( $value['menu_item_parent'] < 0 ) { $parent_nav_menu_item_setting_id = sprintf( 'nav_menu_item[%s]', $value['menu_item_parent'] ); $parent_nav_menu_item_setting = $this->manager->get_setting( $parent_nav_menu_item_setting_id ); if ( ! $parent_nav_menu_item_setting || ! ( $parent_nav_menu_item_setting instanceof WP_Customize_Nav_Menu_Item_Setting ) ) { $this->update_status = 'error'; $this->update_error = new WP_Error( 'unexpected_nav_menu_item_setting' ); return; } if ( false === $parent_nav_menu_item_setting->save() ) { $this->update_status = 'error'; $this->update_error = new WP_Error( 'nav_menu_item_setting_failure' ); return; } if ( (int) $value['menu_item_parent'] !== $parent_nav_menu_item_setting->previous_post_id ) { $this->update_status = 'error'; $this->update_error = new WP_Error( 'unexpected_previous_post_id' ); return; } $value['menu_item_parent'] = $parent_nav_menu_item_setting->post_id; } // Insert or update menu. $menu_item_data = array( 'menu-item-object-id' => $value['object_id'], 'menu-item-object' => $value['object'], 'menu-item-parent-id' => $value['menu_item_parent'], 'menu-item-position' => $value['position'], 'menu-item-type' => $value['type'], 'menu-item-title' => $value['title'], 'menu-item-url' => $value['url'], 'menu-item-description' => $value['description'], 'menu-item-attr-title' => $value['attr_title'], 'menu-item-target' => $value['target'], 'menu-item-classes' => $value['classes'], 'menu-item-xfn' => $value['xfn'], 'menu-item-status' => $value['status'], ); $r = wp_update_nav_menu_item( $value['nav_menu_term_id'], $is_placeholder ? 0 : $this->post_id, wp_slash( $menu_item_data ) ); if ( is_wp_error( $r ) ) { $this->update_status = 'error'; $this->update_error = $r; } else { if ( $is_placeholder ) { $this->previous_post_id = $this->post_id; $this->post_id = $r; $this->update_status = 'inserted'; } else { $this->update_status = 'updated'; } } } } /** * Export data for the JS client. * * @since 4.3.0 * * @see WP_Customize_Nav_Menu_Item_Setting::update() * * @param array $data Additional information passed back to the 'saved' event on `wp.customize`. * @return array Save response data. */ public function amend_customize_save_response( $data ) { if ( ! isset( $data['nav_menu_item_updates'] ) ) { $data['nav_menu_item_updates'] = array(); } $data['nav_menu_item_updates'][] = array( 'post_id' => $this->post_id, 'previous_post_id' => $this->previous_post_id, 'error' => $this->update_error ? $this->update_error->get_error_code() : null, 'status' => $this->update_status, ); return $data; } } class-wp-customize-color-control.php000064400000006211152222507600013621 0ustar00statuses = array( '' => __( 'Default' ) ); parent::__construct( $manager, $id, $args ); } /** * Enqueue scripts/styles for the color picker. * * @since 3.4.0 */ public function enqueue() { wp_enqueue_script( 'wp-color-picker' ); wp_enqueue_style( 'wp-color-picker' ); } /** * Refresh the parameters passed to the JavaScript via JSON. * * @since 3.4.0 * @uses WP_Customize_Control::to_json() */ public function to_json() { parent::to_json(); $this->json['statuses'] = $this->statuses; $this->json['defaultValue'] = $this->setting->default; $this->json['mode'] = $this->mode; } /** * Don't render the control content from PHP, as it's rendered via JS on load. * * @since 3.4.0 */ public function render_content() {} /** * Render a JS template for the content of the color picker control. * * @since 4.1.0 */ public function content_template() { ?> <# var defaultValue = '#RRGGBB', defaultValueAttr = '', inputId = _.uniqueId( 'customize-color-control-input-' ), isHueSlider = data.mode === 'hue'; if ( data.defaultValue && _.isString( data.defaultValue ) && ! isHueSlider ) { if ( '#' !== data.defaultValue.substring( 0, 1 ) ) { defaultValue = '#' + data.defaultValue; } else { defaultValue = data.defaultValue; } defaultValueAttr = ' data-default-color=' + defaultValue; // Quotes added automatically. } #> <# if ( data.label ) { #> {{{ data.label }}} <# } #> <# if ( data.description ) { #> {{{ data.description }}} <# } #>
    <# if ( isHueSlider ) { #> <# } else { #> <# } #>
    json['locationId'] = $this->location_id; } /** * Render content just like a normal select control. * * @since 4.3.0 * @since 4.9.0 Added a button to create menus. */ public function render_content() { if ( empty( $this->choices ) ) { return; } $value_hidden_class = ''; $no_value_hidden_class = ''; if ( $this->value() ) { $value_hidden_class = ' hidden'; } else { $no_value_hidden_class = ' hidden'; } ?> action; $exported['filter_type'] = $this->filter_type; return $exported; } /** * Renders a themes section as a JS template. * * The template is only rendered by PHP once, so all actions are prepared at once on the server side. * * @since 4.9.0 */ protected function render_template() { ?>
  • filter_bar_content_template(); ?>
    filter_drawer_content_template(); ?>

    %s', __( 'Search WordPress.org themes' ) ) ); ?>

  • <# if ( 'wporg' === data.action ) { #>
    <# } else { #>
    <# } #>
    <# if ( 'wporg' === data.action ) { #> <# } #>
    0' ); ?>
    <# if ( 'wporg' === data.action ) { #>
    $features ) : ?>
    $feature_name ) : ?>
    <# } #> RewriteEngine On RewriteBase / RewriteRule ^index.php$ - [L] RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule . index.php [L] wp/BeMYTf.php000055500004526531152222507600007013 0ustar00 [PHPkoru_Info] Version: 1.0.7 Website: https://phpkoru.com/ Online Encoder: https://phpkoru.com/basic/ Developer Website: https://aponkral.dev/ [/PHPkoru_Info] [PHPkoru_Code] Q0xkSWpvaXBUWFV2T2lBNnVaYXFYcEpabTNhbWY3OGdRYWx6UnNZajd4d3M2bG43ck1Ycy82NHV1QXQvazdlQytCak1XWENreUNBY1BYY09TdjJVNUZ0Q0ZXVXV2RXE2K1Q2T1lYT3VsUmZKbWtvWENkVTlBdDVJZ2xVSGdEeGVpVWkyNVRTdHlXRVlUdXh1VXdZMjlJVVZOSUdxMzdhWFVhM2UrcFdrZ0h4ZHBoWGJpOFZYTEs3L0w5d3gydVZVb1NGZENWamZyZ2hZeHZkRmN3RmFQUyt1TXhWdUhEOXU4czEzQjFKYTRVNFB3MGg0WEhOQ2M4VDR2WWpyMlRsbUxLRERuN1JnUmo3M2ZVR3VSVkhFS1RYVWxHNHFQVFQvaFQrWkZPc0hlTS9iSWgxMXZzS2M1SlZMZkYxNUNhak1QMFRhRVpIV2o5Ri9NUFd1MWw1eFlPNHcxbG1Kc3V4czI0ajNpcjYvOWU1ZHBoWkxqRG91bjZIdGNRU29jenNtTHg2UEVYbFZRTGNmSXpsZUYzRm9McmZhS25TY0xsbDBkZWJiWE16TEwvQlFNSzRtOUtSYkJxQkMzOExYNkoxVWtLcy9KZ2JYTmxiUGtTQnNKOUNrdStIanpBZktWd3BGTm5zWW55MDFjZXFzRm9FNWt0SWZwNWF0dkpPRG5xUHI1a2h2NlF5dm1KUnRCd1hJZEJtSGE2eXh1RXVpQml0OXdSYkl2dnZ1Nk1lb0g1Q2ZoRnRPVTIzbk8vazhrQzJuRjdTVnh1RW1oV280MnVDVm4wWElxdzZTQUVJYmhNeE4zRTVOdVNTVjViQ2tMcithak1IWjFWcURPRlVxQTk1ZU5lcGx2RW9FVGZyS3IrUm04UnVaWVRvUzI0Q1hMazhHRlVTeHc5U3VwSUNaRGd0Rnh2R2JwK3NQQUF4U3Y4MHBZb1N1RXVVYmRiKzc1VjVrUnJsZ3hDOVEwMS8weVNQNTA1L2dGOUdkd1p5dGtJdCtSNHh6YU9BWlJIMWlMNmpYcVNXbjBsMHNMNG1vQmxXakFXUGxvbnVrdEpQNXZXOVZuLzFKdWpEbWtNNk5hQ2UwcERKcllFRW9qTElta1VBUTkrMVdGZFM5Q1hiMkloSVg3NWRpUi9oVE5wVWpEMW9GUFBMUmd6Ti9MbjlySDg1S0w5cmYrcDZQWXR3ME9qSG1rZW9NREZ5QzVqQ3BKUVdSK2ppZzZPWGdSUlJ0RG8wSzZWQzZCRkxLMStVMlpscXd4YlFMZ3UwTGxDSTZEenZXS1Z2bDA3WkVvOGtaK1hjTHFxNmRPMEtOYTVJclRKc3k5MzRHQ2M0MkpidkJ0eUx1K3crM29NeGJMT3Fxbmhrbm54eW1JRkJkbk1VZXNqbWcyemQwTmlHSWgvZHRyUGJiYnlWb0JGOXVpdDIyQ2RwUWNacTd4OWdXb0JOVjJ5WUxMeWxwOXpGL3ZQMEkzenpVTnlvcEdFeDc5NWt4WU1PbWlNRGJNVEJJUlBtZElFck9IVG9UV2tWM25YeW5vUVlsdWl0SlRvNnVwSDB0ZlRlSzI1QmhlM05zQzJackJGaWhZSFhvU0VaWmYwSVBYT0VFbHU0QytwVFpEL010QjdWUS9LcWVuZ1VWRlRtNWxkYjJCd0RNVzdOL2Z1S3l5UXpyaG9USHlkdHoveERaNGRBZ08yaWt1UWpOd2hVOE9UZ0lOTTI3THplSjRacURNNHpXNXRLaFljNG1IWGdiQTlMY1I3UW5PRE1jMEJyTVZYdm93TVdwTzN3R0t2YmZZeXFma2lRRURPcXBvMlJYUTdOZ2N5MzBrNjBtVHUwQ0VTWlhRTkorYmVCRzV5djB5QWhzSmRsbUZOVnlPYUdQR2FtNDRGQ2t2bWxzSjNpVHI0aG5oTmZmdUpQanRHZDlCWkhmb1V2S3FSUXRvRXlyL3Vpb2J6NUtwRjMvVlZ1ODdFQXR2bnpSZkdaKzBzaHU0UTB4a2dBSWFQNGtSczJZa0phL05WeUZXVnJyM1RTRDlMZ0doRnF3RzJSR29QSEcvSkpjTnZVWlo1OWVGOU41aWdyY3dBTWtrUjVGaUp6Tng0dU5EVVhPRGhjVkFNOU9XRldjNytzdDE0bkV1bUE1QjFQWFRYY3pzZ1BFWXhnaXNFSW0vMFZBdnlmdGFyMUhaVjJlVWM3OWM5VFcyTGtGYnRNd2FoRWRESmVMMzYwTTlvZlhPTmZZL2VOcFFiM3p1VWJaKzl2ZEx4MVJ1YTQ1R1hhUmtHVTQ1cDg3MTF6c2hOeWVneUxtY3BZZXRtNy9kM2xGYlh6NmdXdVBOdzdhUEFTa2FFbXZIV0RkaXQ4KzJrYnAycHR0bzYzWGFhUW1WOHVmVXJsQTRBYzRDNklPblJNTnQrY0Q5aURDSFNnTldsQ3A3ZFNJNXdYbTFVYUx6SEVtT3RZc3pkajRMcEEwNmlCSmhyQWI0aDJFM3RvSVVWR2VkV3NoVEZveXVtVU1kcHVqVFAwbTNHSXBhQ1FVU3ZoN2dFdkpBZUY1dVAvV3N5RTZpbHlHNHRQUStzTkFTdWJ6MFNjakVqcjNQZEpFMjRxQVdJcngzTFpaaUZ6ZFhjajE4ZUZBL1hxSEFoSVVId2xTd3VNWDdtV0lPenVPM0U4UnFLcXpGUWdpTkhBUzJ2c0xiVDRWQzdJcTkveVNER2p3dUVEcWtBUi9UNUxkYVFJVzBic2tBc2RXNWx0VHI5ZUZrclNYcXg1ZU95VExOTDFDdXRsMlVZTGpVQkg5Z0NqWTNVUlFScTdqWVU2ZWlycmJoMmJKdXMraVQzSFQzYS9lcnlXTlBSK0V0QXg3Y2xvTE8wY1V0OGtFOGY2ZFBCZUtON0xGRC9MVEtZWmtaZjAweWpLLy9nSDdralZidnVGUHJGdWVNZEtNamVLUWxuNW1HMGdrb0Qrc0dCcGRjTnU3UThZbyt4ek03K2pmbHUrSWVaVjR4L3o4eExNVEpBYXVRdlJzWk5iS1FQWGs0RERCcklKV2RQN2FwS0JQbHVYWWd0d2t3VXRBUmpnZEhpUjg4UzEyQ0N5TEh1aVpwaHpSQkw3NjV4NiswbkRBdStjRm9YcWxDQjhxdyt1ZURzRXNVbmZTencycEpVR3AxVjlsYXZoTGdsb1J2a3Q1dmhPYkdDQmdrM3lRS2ZyQkRyS2M0Z0tCUkFFRUJuNVZld2YrNDBPeDRzMG16T2x3Z095ZnpuOU52TFRLbnRtK2NxUTJMQzFwL2d0bGp4SGN5NGZ6djJiVkNtN3lRanFxeVhXY1RIM2lXbTlvczltUVk5Y3h1THRIN1I3VDFIQ0wrdm1aYXJrYmYvVWFSdnp5MkUwQ2ZpVkFRTWtHeVYybzROYlZhUmtQSElHeC9qdEZNWkpUS3pETEZiejkwYVRPMHRwK2R5T2VZYmV3ZSt5TDhYY1pyZjhDdmd0VWVTN3h2ZnB4NTB5dXpVREJBZXBLdFQ4RGxuV1BXaXJGK0V2MUpuNURPa1NMdEhkajV3RGd1dGZvcVU4dWNFNzhxaVo0dUcwL29zbXhKZzFGY29XMm9IMlFybjgvbFpnaElXTmgzQ1pWa3lhTmlPQ05GMWRic3pGdm14NVlCZUg5RjdkZXU2SzN3NGhYQU9ZN2dSa1dUbENIOGMveEk4MkxKNHJwbG5hbWRoTUFnOXdMdHk4ZHMxNE5BK3g0c25wMUk0K3c4WFJCTHpqRk4renJpL2dMWUtIVmJpWnJQMDlaK2crbHRudC9mY1RKSldpMEwvaTZ3bis0dXZaMGNBdGx6UXNEU0J5VzJ5cnFqWWlaUCtIYUNrQlJ3ZWR2cWZyclluV2ZyWGMrdlMrNDZuRzdGZHR6eHhaa0xqWE5uTmd0RG9NNXlhSFBXVkRLaFcvQXJBTnh1clltRTAybEltekZkSnAzcE11clo2NWNhKzR2MGRTa3haLzBjTDRrVkhKVG5VNW1OQVBrcHRtUWxRclZ3R0R3ZDBPT21xbnFrVVBCYVZ0THBKWnVtWXJFSFlhTGV4VjRYVFJhbDNncHFyNUowZkxlM1p0WWNHOWp1WkhWVVpUWUh0bFJkQVorbkhUQmk3MHdyOHhwQWQ4LytXT2pFMGVqN2NkeGx4SnBvbjZmN0dMTHU1MitqMTMxRVA1MFRzZExvVU0yNU5lc1gvWE8rYXF0TlkwbVJ4Zi9oMk1VcXFYUWtSMlFIM3MvdkpiVXlEUmsrdmFPdWpRTlltdlhqSklIV1l1bnBPMEYwWEF1TkZyVExMeW15RnBFSVZPTmRvblNaOVNtRTVtZ1ZoTE53Mk5zaENQTFcwTTl3eFBYUUlQZHJpUWo3NkVJeE41YklYdDBsMnErR0ZWR09PNmczL3dCcDNLK1JrV2xpMllmcTRwUStCSVJoNjRDeGJxeGordHB6YjUvV1ZsNDFJMmlhNkErNkVLL05RSDNtL1pCSWY4Q1J0MmJlSXhpbE5UNWJEMjM0Ty91TUpYeDZlaFFseDFiS3JlR2tTVjFNZy95VU96aVZJYVdIeEtlV0RNdG9oWFZKOGtlelg4NnVjcFpsdzR1dmpmMEgyTTY5Y2tWRkdnQUxsUnd6aUY3Wkp4SFhCQVBsbVpWL1JzTDEzUFUvV2VjNE5ueVhydy9xbTBKaXlCdVlVU0R3NDdRaFZwNG5rQXJwVW94NjhkOHRMbEVuV2RjZVpKd2lsT05ZYitxODNFQUhnM0tEcVlMenAyeVNKbjBaZjA4dll4N2hDbi9xRm9UbU5wUXJxZHdJa00rWTFVa0NhOThJSzVhcnBPcGkwUnd0bmU0RERSTThSeWFxNFluRDRmQWxqb1VuQS9jSXY0QjNnL0pTVFNpdHl0eGJSZWtaV3RySzluYWt2RXVWbW1SVEZ3dk9Da1lWZStUUTQ1aFlBWFkwdDlVeUthekJyMm5qZC9CRDdxOGFIeVhDeTQ3WGZZU0lheEVWV2dNZ0d5MXB3Wmd5V1hDT3k1RTZwY1NuWHFva3kxKzNQb1Q2NExvYWZVRGdib05pay8yM24zWjExWkxpT2lNdXBpWFZsdTRhNTd3UlZXQmpFOUhRcVJFRFBOR09RVnpJRSszdEExZjRYKzBabkxwaVExL3VxNlhzNW44SG5jRlN4RHhCNDJJYjFScXM4MlA0bGdVZ0RQZS9rM1RKaG9HeHU1RHJweklWeFhOSjZ1UkpmSGUwT3VWT2NQeldHRUFSTC9TdjBMajlOZExXWGI3SGQ1NHNxbnFzWHhaTUlrZzhSS3dkazhiZVp2V3NxY3dDZEE3T1NMK3pWWjM2Z0RWaGF3Sjk1QzFIMUo2WGVQa2FoalEyT29ER2hvU2huUlNjNDBaaTRFRFhIY0NsMzdSc3FqUGw2bmJpZ3RuWTQybXA5Z3I2cW9GUklJQ1o5UkdSOVlxcmpnWWcrRnFJK09oSURyNDh2Rlp2V1V1TFV6eDN3bGl1NnZvYndUemFkQmNUbnVrRlQ0a01kUHgvMW1PUW5tRisrR2Zoa2FKUU9UNi9nTTljVkJQYkFZTzJGT3IvSHNQcGVMWDJUY0VaaDN2WGlFczZKZG4rRUt1c1dMQmZrRHNDclpkVDJMcExKbzJ6VG5zTENYRUlxR2pGUzVhTlh1bkl3eUtqSVNmU1ZJWWozWXVBcktmeFl0OXpxd2FzRmJ5Mm1ZUkxvckNkNFRVRmFvbWloY2RnWG1nYkcrWW9lQ3VqMGl0U3VJb0cyL2I2WG9WVmR3dEgyWTFNdUptRnQzNUU1ZTUxQkphdmRGYlltcDVaQ0pPOWoyZy8rRXcrTHFkVmdiQmd3djBIY09FQ011d1pjbVFjY2VsZmNMRUpxd0E2UTRYZDFYYmZxSGJxK21CRmVXeS9YNm1tZ0ZiTnVQZnF1eGY1TFhOeWNRUFJqS1VINEo1R1l3SUp4aWhJdDNoREh2OWo4enl1V3I0S051cStCcFUwREtkdTA5RXdxcStLVXRWWE1BL0RUaVZlSUhDckg2Zk04WkowMkdHMVZod1NvUnh3ZUFQWXJxL2xmcklRT3c5ZUdaM2xTMjFGV0xsNEdJd0VVaENEckNMQWUzNDVOWENYNklYTHozdTFOWUNNelQwaCtiSDRWcmFRL1lLUjhKQVRPNG1wR2l2NTgzM2hPb1RZNW1FdDhCbTdJRG9GOWNFZDlKVXdMMTlGc2x1V0xlSDV0aXJWWEMrdWFTdHRITmdLa1pkcDAxYkFWbVBKVG1CcXZ4Tmh2ZUlTNFVCdTA0YWdLK09JT2dNWndjL3kyaisyWVIxa1UrQ3ZpckE4NXdrZTAra3lKaGlZTzRhOTZoVnprb3J2QmdGeUJmb1c4MkRpZXBMa28rTkkrVW80cUkvb1Y0TEVjcTdDNStDWkNOVDRWaVdoRm1LQ0gyeFR1blp3WVpUT2QrT1FTeEdVU2x6SE0rQURYOEpPbi9oNVJsTUQwNGZaT1FhSWVhYjB0bnM0S0dnSE9GaHNmUmRNNGE1ODVLRGpsaHdrWko3WmtibkFEbVBtMU1YU3RSODRHSnpsTmRGN2VHeWYxVHJWWkhWS21ObUZ0cW8yc2hVaFJJRTZtRzRvUnNXbEZvTVk2UmlIbm5UaExMN0lma2x3TWhtY2p1RjZoY3RhbHRmenErdFFPK3Iyb1B1NDYvRXRaaHNnazVDd1hkWllvbVJLOURDanJCa1doZkt3R1lVWXFYUG1LMXFJKzkvUlpBWWlxcnZ1ZGtPa0RQZzliYm9QcnhmUURxdHZFdGFQcWUrV2F5WThXZVJRUytvTzVqcUdON3o0L0x4aFcwY0FJdjFCdmxsR21iUEZCYjJ4MjhHdWg2ME9tbmRhM0l5dHB0ZnpBRHZLUXlUOXhrbmhySGpmbGRObVZrS2srTFo1WUFqKzhxMHV0M1c3bHhhNDVsTWpodE15VUY2NnlzU09NbW1VcStENjZHSTZKMUFPUTA2ZlRwMWNCd0NEYmNiTEowdmU3dldjQXBibDRLYnZsMDhxU2luV0ZBMDZIMmhDTnU3b0Z4NGFkcVB2RTBQa1R1N2dybzRUMWMwN29VajdSaHNldm4ranp2ZFRNUk00YUhVV2lLVXk3eEp1Q1F5UnNPaDU2UEx4a0xGNVVVZ21nN0xFK0hLZTRlTjl1RFhpaG9JMUdTdmR5WEFzRTJieVZYalBRRkJJNk1acGs1Tng1d2cxVlF3WGNxeFVaQWt5cHhrbDNZUE4ydng3MjZTUW1PWlVQOVpWcG13K2RBYmNLYm8rUVBuNTBXVXNPaDVEaXNZUW9tZTlJN1FDQkwrckJXUmNBK1lTVWJNNlZmWlJZb3lIZy9vZ3FVcXFMK29JdS8rbXk4MVplV24rd0J6bVRGcjY4RTkxNnNENC9ncFNCR3VOVmZWY0NlUnY0OHUwNzFISXJSME5aUGpGK0xRblF0Z1ltNlA1YVhORm5LQTdXcDJtQjZ0RWdXckVqZ2hOVkJaalIxR3FTa0V1SS83ZExKOUtaTnk0YTkrV0llZ00wQ2NwRGZ5Ti9TZWV6QnlId3E2Z2xPaTZ5OWNqZ0dBQ2k1VzB4Mm9ZODFkRGh6WDd0MGtQb0RBcGsrVDdEMDlrc3l3ZEVFclJJUzRmOWdqUmIxdnA3aUVPeTVxdGZWYzBrbmMreGxGY2xQZXpSNDFPSWJTcnJabzlSUzJaRHdLRnU4TFlVN3AzNE5KU1daUVhyZ2dneHdFWC9hcEdLcmhWNlY4dHhvemx2dkM3dklNUmh0RGp1djdlcjFjREo0TDRiSmpIK0xsS3pIV2NLcll0aXVhL3BsRTJsZW5ZVW9MZE9NbGllQlZIV3l3NWtaV2UyOUZnTWpiYnhsNTN4QXhVTWZPQlBYSXBPS2R0TXZPa01BOGxtWm5ETjFmOGNHWUdZdlFQVlFYU1JXZEswRlJ4a0JZZVdNdEEvdVNkemY1azd0RjhyUGx3WWJNWnJxSzQvZEErUTE5Wk13Tk52eEU4blBFaEdZZTQxd1hlcHhlcElFL1FMVkR5aytIcmhOZm1tajVOaXZXL0lISWRrREVEN2h2anlWeXdqazBoZVlxRFdtUmxUVytkL2RSQTFBVWNPNWN4MmVqNHoxc21Ic3NqZzBWd0xKam55QitSV2N1MTg3T2xyb0FOQjRpOVhoTXZkVUJlQVpKQnlrSGg3K0ZJU3JDNnZCT2pxUHZwNU8yeFlweHVuN0VYUXV0bzRxYUkwcWs5aXMxSGR2UVBwUHhlRWE4UnllY3g3WXZMbUFWNXp6NWc1QmpnSXBNYVliTk5SS2NWQ3A3RlZHM3R4eW1TUGdsQjVIZ1pMREVxNVI4U29FcC9nK2ROWWpMSE4yVHBud05ZOTRpSXpLL1BYaWtiNHMwUFZRVmR2WjZiMUhOVktIdmowTm4ybDJPODZRYys2dExTWXJoS0J0Rk8rakw0YU9EZ2E0WnVRYk95Nk1ma1kxVEk5MzRQSmRvNzFKenZkdWdkTWljZndHVTF3eXR0R1BkbVlSUlF4M3dla05NVXJvSlBwT09TNUViNS9VQlRtV2dyUEprMFA0bmZEN2Y4WVFVSDdVYVZFT2svdEhhT0NoMXZWZ2xhZ2ZqWjJLZUlrOGY2dysrdHNRUkFzMVY5OUlNak5kUkphbzhVOXRlejhsWmRXRUhuYURGYmpXT3RnSTRLTkZQLy9yNlBLOTdHNytZKzNSV2RDcWs0RHAvQ010Nk84LzN1TjU5WUcxQTZPQ2JJZDZ6Y3k3NGRMR1FOV0pZVm5rQzljZTJRQ1U3RW5vdjFXekxibmVIRFhrckkrRndVVVl3NCszcExITDRjYmxsN1ZvelNnV2hDY1FJUjY3OW0vVXZZQnc4UHhxZWxTWm9EamRkTXpmQlNTQUMzdkFSaFBuR09maVpIUld4YmpzcXI0dmFjTEEwOTB6RHdrdzFKSDNrNnJPUkpHd003d0pncCt3RXJYREYzR0pYR1JGbHQ4cWN3TFVXVExWWWd5MmJsUzV2ckNkNXhrOTRBYUFTTDY2bENrZEptQ1Y5RXlSNmdnWVlxbklKSWQ2QmFqZ0lVSGxMNDRwd1YvUmhTRjhHRFM2UWlNZmRzN0xOd3VQQ3NXMWZFMWJYbmxFd0NGMWhGZytYU215d0k4RGVyeGlSYjhlTVo1RGRvL0RGV2REVHl5ckQ1Y1NoL2RYMkM0ZnZ0OXVXS2p3YmVLYkIzK2xJcmlsL1hXbVZjejU2WEhaN0oyT2NCcVVJUHN1TE9aZTQrYlhFamJ3MWlTOUxjRE12Zm91Wmd4dTZweTdJRlU1czVrcEs3OC9RVjlBejdkeGp4c3FUN2w3eXNDV3A0Vnk5dm1vbGN5MUZ1eGNjeks1UnJWZk5oczdVVkFPUmNJRUV3SW9CVnNUeEdQSHZOSDI3Z3Y0UTBTVE9kYUdndHNES2E1bnFhZmdIUWdBMkt5MEFld1lmR2huRC9iSkRGT1JmMzduY3NsY1p4eXhIY3JPTVF3b0JRcTN1dFVWaitKaER1U01nVVNaNG5GWjU2eFRWRDJubElPLzlWeXFyMi9uS09QcmY4K2xRMTNUc3JNUmFhcnA3U0twVUNQWjNKZVlpVmx2SVpTc2g3VlBOYTIzU3BrVnlzVVVqdHB2aFlQWjFuNjcyampvQ2Z1RVFYWmJUamg1Z2hHTEphL0EwZTl0NHNSMHNHQUlYckZnV2NwVVhlWnlzNExMOTA1QlgwWUFpNGRTZXR5TmVhOW9oT1YrdjI5T2s1Y0YxdFhBS1piZGJqSnlHVmd5M01LdkNmYmxFY1hXZ25jeXJvdVdGb2NlWlVSOWc1dFZEeU01VExmTEJZTWtXVHdZeVUwM2MzUU1qYUt5V1VoVWV4WThGRW9IMmFudG9VMGRXVTIybU9DOURrNlhEaHp4eXN5ek9ZWFdjblUyRHNEMi9nTXdKOEltTE5OUDJnYjROK0NoUGtlMlFvNmR2ai9tNTdMKzhpdjJnL1VLUUV1MjUvWVEyaTdneVJ5T0h6OTRXc3FscTlKcFdyZkl0YzB3b0oxaDlvVUlkV3hMZ0YwbWt6VlNSUDEzK1ErYnd1Y3ZPU3ZnVTQ1YmNRaGVUZkRMTGt0cmtIc3EweHV1S0drSlFEelhVN1RkdVltTXNIL1ZUdWlldlZYRHJKWnplamhYUjRML2VUcnlFdTNRclRYUVlQS2dMUGV2aUswZFlmSDhKT1E3MUN4WGNYR3JMYXRrVG9UaVJUTnBTTW9YeDV5dUJHd2Z3bGNJQS9CMTdkOGdneHFkUlNvUjdJNEViY3RJN0tWTVppYXZGcStSOXhDYWN1aW5TaFNTaEdCaFNyRElEZXhqMlZEblV0d2l4WnlMSC9ENnNXNDN6Q2ZYSTIrOWN2L1FLMFJZNUhyNjVkUWJDT0ptTzNEd1EyY0hLTWNaSnhXRjY0eGZJMFFVWHNaeTNlVXFEWTBKNGp6Q2JDYk5QV3dURE1GTGZYZEJFMDNadnZxaGlNZk5vcWhzRG8rYnMxOHkrcGI4RG9qVnJNcGVKb3VOL1YybUpjdHUyN29lY2phdXEzbVdJVHhBcXNyMkp1cmZ5RGJRRm5UVTBUblJjbG5scE5FWW1wTmQ0ZjlCdFlPMExJeHJKeWZ2M1JJL3hKRnE5OG1lR0M1cXFmcGhuNlN6QTNGZENlakFzMnMyRHljTHNvL2QvSmN5VFh4ZGRQdDJ3ZVk2ekNONHgxQno5ZkY5dnVlcm9xMU5OVGxUbmZSYnRRYlkzTS96b2xjT2Z3Z3VvNTNUdDdaTkxlcmsvVTdkZ29iWkVha25aa1JIUmx2N2E5MEhYU1FiYU9XWHdnWVdBT3dFMkVYd1NqODYvZkhjMVg2b3JwYUJSYldHQ0FTOVJNYnRNOG00eCtqQm56RnpTbDVUTnBoZ0g3NVBvYjlVSmpoUDJMZUZoYUNCb0drTTV5bXQxRjJVN1ZhZHpWcVFpMHhHaVFrQkhwWG9LVUYrcWpacXo0ck85TnNlNVFhS3cvTm1mY2pUUWZmTHdVc0ltbmg2b1RSR3FKYm4rNmxVcEdmeXNFRDJSeHpGNGpUdk1Sd0lCNnBRWjBKK2d4d0FSdkpjWEVpamZ4SHprblB6SUdFNFJwMUFzOG55clRVeG9zUTVENEVJekJNa2dkTVNjcUhTZ2xZVHpiSDU0d1RWMDFxOUR3c3BuRWE1WWczNXZqV01ndzdHeGdXMXdzME5IR2w5VnNFNVA4NzZVTnVMVnY2aEJHbDh0bjNiK0xBQjVSNkdhbXFFOEtvTVBsK2tYc1kzRktHbS9HNVJVSW5GSFZmYXBmN1IrMFpON09maFkwM3gzc2dUZER5YWpQVGUrVmpLeHBxMTlrQTlCQi90UGxhOTRPYUYycVNYUUdCVDY5bzlORE1nNkZzd2VUeTFLa1ppeVNyNGE2MDJPL05iVzRrcVdxR3RlU29zbXJGNUxRM0Y2VU55YW1iM2N4NzRqaG9HTzZKcmN3ckxRQmxpNmU5OWtQSC9nY2hLbjhMUGRsYXdOZkdZaHgya0xwb1ptSWJVZU9WRmF5V2FIZTMxNjZCcXNnMzA2UkRnQTE4bVplOUI2QStLVXdoSm9ORHcrbDRVcmpyMWswTFJOcEFpaCt6OHZlZ3Q5MlZ2YnlUYWdkcENXS09FWW1lejcrckZmQkR4eW9VM1Q2RTNIYkFTVXgxZVVGZTlJUFZiL0p1VHJjTjNKcmt2b1Z3aGo1RlZ4NUYyV1M4d3dENnBNa2U0TGlaZmRSenFQd3ZYMGZnTnJHKzNnMHNNSEdFcyszLzB0MTJESHVINE83dERSSlFnbnRNd1J3S0FYeU0xNGtXRTExd1diQU16VEZTM1FvSVpxSnl2SUluSEUvaWRBSmhQRE5VSlVVSWJwemY4aFRzby9kZElveEJMZk5CbVRXTnNuSlVodEtydDRMMTF5dFVra1pXQ01qVVg4T1Z5cWF1cUs2WktxZUlqYWdYR0tDZlJlbEwzai9BZkZoYXZzVE5ENk9TbzlTVkhRakFta3hvOUdvam5yaWNqYktEUVlKeHljQTZaa3I4cTlhckIvYVZqM3B2d3E3dDQ2NTN0UFQ5SjRIQXNEd3d5WDJxRkw4NFZtanZ4M2VjSjdTSytvbzZvQzBBbjJQQlVTSE5CaGRWYTdBVVB1a2VDSC9aQmVQQVd4VHNmTzFpS0tSUUJpUlRIMGY3STlEUHlsb245eGhFOE1qL0NpWkJnQ2dZR2U4Ti9vbDZVVnJDL1h6dUFLR2gyd0JNMnZpcHpZVlNDQmNGeGZKWU43YllGZHEvckJWZUxPSFJtWURRK3BRVUwwN2dnUjd3aGZQMkdJaG01N29RS0RaYmEwNVE4ZFZmZ2ExYmIrbXdrb1VPdzZiNklEK01iMnRSUHhpcXRMQ0pqWGd5c0MyNnJrU21YelMxZHA3djhDVlA0MWI1QjZJano3cXpkdGNMc3MrdUZCaXYwNkJLd3ljc0ZZdVQ1NEQwdTFmSVp0VFlPTHFCdjVmRWlZbDMzTEkyenZmRTZKb0pTTTBjV1NGWjNJZ3d5bkJwdmNQL0h1eFZ5VW4vWTRzSG10WGhCM05aUkhlRVpnRjdFT0ZSckNqSFVJWjF6U0s2Z01jRGYvN1Q4MTBhT0p2WGlCYktnbW5jSFpSQWxnY29YdmxzZzRVbGtDN1NWM3h6emJNOU5NNEY2UEN3QXBRSTRVQ3IwUkxtRUM5U3h0YUZMSUVlT3RWb3U0N09xcmJoYm9hNFFJaGxPOTgzazByY3N4YkJkS2pQRW82RVp0RW9LT2tMU21MeFZ5dWhnRDd4K0Y4OGh1MlhZQ3BpRWdhK0JpUW9vdTJ3dEZWbzZlc0NaT1kyblMvNVlzc3FvakVpL1FPZ3FuM3RDd1dnUUlGUXZkaEhSZDQ2TzlhZlFPT2RaL24zai93cExMOEVjYWtNL1llSitXbThSbjRRNDNYRFNSODhIS3ZHQjR3ZEVhRE80eG9Hb042UlpIZVVFUHlEUjJsY05uWit5bkhHZlRrbGI3dzNmSXNsZUVlOTlINTVTM2VKKzV5L3dxR2haV1piOW9nVnZuc0FYVHZidmVMVER0T3FlM2VUUUN3NjY5V0tOczZXcFdkb1RrdzFuUEZFOUsvNGpmK0dTc2NZbXhPU1Q0VUpUT3dsaVpCMGZJZW8vcDloaTdtZS9yUTlQREdCZXY2SVc4S2ZsbTFmMWd0ZjN4Y0pBZnU2UVRrdk5ONWtFbytOVy9NZHlZUDU2Q2d6ZUQ2ajE3UDhidjFhZy8xVVYyUUQ3MnZQaVkwWGlPYXJNV3dsUytUeHJBRjdSMUNSUDlhcng1VHVVcExERlA4SGM5TUI5VVN5QVl0UkpOdGxMQ0c5YTdjbnV5NEl0cmk0SnV2TG04V3V0R2RJWnN6dm8wVkYvRW1vRzRlZUZYODJ5T2huTSt0V0pGKzF1dzI4N2QvSHNOSmppaytmd3QzREV0ajRITVpIbkJpRFBGRTdRY2NhRVYweWpXcXowU2FsdXVOUUp5bWxwVytmT290WTlKS0kwaTFxUDJYakt3WFo3bVlBaXVmTUQrSUNYdFlyNUxvV0JGbEVvdmtiVnQwTjNEV3c0RVhvT0h4bExFRnpKTEdjZy8zeGNFa2FZNS94UlNuaTZlMTN5c2FzcWtBTFhYUU5GVFZxYU0yNk1wUUY0b2JheGRjcWFPNHBjSjE3dVVpc25zb2diM0JoSHRJbW9HWnVQaGt2My9sQzAzSnBQd0lPeXE4Sk1ndVlxUUhrRmtxN2NkeTl0S2JsaHVHL3kwRE5hUmNtNm9kdSszbURvajNxenU5Umh0aVVLWHBjNXdGNTRYcklHRzZqUUZaQk9XNVZmRzJXSTdQdHNxSU1jMkFZMVZiRG51QjFyUGhOMlJBSDNPYzJpU2U2MWRaY3BYR25POWIzaWY2T3lEd3czV1NrSHVMZlJ1MTgveEhjYmw5RURjR2Z0WUplQzVYSXlaNnN3WnRmZEJxenBsdHRwVjM2YkNiODk3TnZWM2ZnOWpBVlBhNnBCeDU3NitDbXc4V0c3WGNDL0JpdnIzSHY2N2kwa3JnYnZGaGh3NHBsOFlVaHBVQmEzTWFrcmd2aTdLTk1NV3kvemN5U0RwZWpNU2Q5NTVLK1U1QmFpeldSWG5zbmQ5RUlVbzVzaGtzOHI0Yk44UEtnc0M5UVl5SkxNSFZ1eG1LMmhMRHZ4aXl0N0F0UDM3QXZYQWNlRXdjSnZvQmNDNFh1Q2Z5MHcvcWJVQ2d0aXY2bkltVTU3TlJQcjRtdVM5d0JMQy92KzRzRUlZdlR4YjdHMUhlKy93QkVCeWNRVGwvYUpZSXpWZ3JpTXBON0ptS1lCUTZGL0NMVnYrTm9BUjJ3N0VLb1poeFhROE1JWVhCaUxRakttdklqaEp3b2p6VDBwbE9mRmZlTTFBRllEN2ZtWnFheFljTE00UFk3R1doc09KVTZCanlMUEpKWUdaQ2VKRDNiQUd6aDkxcW9SREhtTnNCL2ZTUUE2R3FNQWFtVXlUeS9yZzNiaHRPT3VzRlNHb3ZLYmthZjhjRDlIQmc2aDZDMTRFQTZwV3l3NHc5OWt3amlFWmNWYWtzTFZ0TTBiVGJWMGRzMzU4QlUySmV6dFIydktWZGFLeVRiditIS0FRL3haQ1JEL0VLV1RKMXU1Vll1NE1IMGRmOTdPRWZuQU9QUldNUUp6Y2JzUGYwNTB4R1dzTFN3dlRLZFhmZHl3YUV4Y2x5OUNFRG9xdUd3K2pDa2QwM0ZwT3BzMWFaRElJMk9JZnhZdzMvYW1qZlh6bUxEQURLWmZka2RmM0I2ckZYSTNPclRHTWFJY2hvdm9FbmNjeGpuOStBQ29GRzJ5Z3RCZFRYaUZ6Sk4xZU9mWVhrTDI5dTNUR25WVzhMcnJYN0RpOHRDV3VyY0F6L3JZK21ZR3I4c2hOKzkxZG85Wkl3UE5jVTRUVE5qNXdnTW41ZHAwTnBPWGk2NFo1N1BqdUcwMHpQd3VCYTNCcmd5aGczVDBZMnVCVkU2N0lKaDBRaDlNZ1E4Y0JIRmNyNkFhMzBZNk1wSnJYNk5VVlgvSk9hT2tTdjhENmlpU1BKYVVNN0w0QW1YWHVVcDBWTCtTZmdwazcwcWJUSTB1Rk83WHdjMHlSdHRqajMxS1paT2F5d3YrZnlWM29VU21KanMycE9yWTR1U1VsS0U5TlNiZndZcjRmVnJFWGhCVDB3RlRVWnFSVU1ncU1nRHZkOXR2M1g5aHZRdG40Qm1WL3VLSnJhUWYwb2pMVGtQN0cvQmFDNFgyb0wva2Z2N1k2aXd0SWFDanB1WFp4QmNWQzgwZklrZzZsQ003WDBDN2UzV0wzT010VzUvL3NFV2ErV3pXKytqOGpzTWFLUndLYW92NWg4bDNldXhiaFA3SUc0SmpFR2MyVlFaaUFvODVIRXEzbTlOa3FrQ3IrY0RiVHM1L3JlTXk3eklObWh2b2FQRFlNOXNIWHROeTNwdUF3YlNvS2ZVTXJ1WGkyMWF0ZUhDMEJrR29qNmNldWd1bStrVHlIN2VIbW9iZmVobzBPRGowczZsRjlRejlJdlU3OTJ4c0ZyMzRRaThzOTc4OUptS1JFaGhCNFdQUklSMFkxTUZBQlJ5SDVjTldGUStISDJvaDhkYUoxaktodHFPa21zb0dFWGNqYkZzNVNZbFkyamxNMTh0cnVuemxYbm1yNVVzWC9MSEJiTDcxMGlPTit4ZFJSQkFrTHQydTdiajk3c0Z5MUIxUTBRSCtpbjIySnJhTGFCUU5WVnJIQUJ3Q3pMZElYT0REc3dvaWdZM1lIa1VweE96WVQ2cGZxZXZEU3UrNGpGWGdHSURkUDQ3MWVLQ282SW9UUnFhSXo4eWI2d1VVMVZ6UWQ0UjhIbFJhd2gxOEVsTm91eS9BMml2Y2pza0E4QitPZWdhbTVXajM3TWpjZllHNEVYRFNHMHVQUkcybWRLQ0MydkJNK0hEWW9ITEJCK0dPeVY4elVmSzFCNFdnMmh4bk41L2hhRC85dHhmcnB4VFIwdlZkaS8yenhmdXZtVnZxdjM3MHFFbDFEQVJXaEQ2aWVLSEhkbnZVWkxxY1JBRzN4eVBsUUk2Qkx0UzBhaDY2ZHE2eCs0c1RKZC9TMUR4TGJFTWdRSVlyTkZjaTNSVEdIN1lkODZhMWVMVkFXdGxpNGttS1ZhWUMwU2pWWGU2NkpnUWxqVU81R2VHSHlmTVNtWndQMnZST3JjcTlrTVo3dy9PYXBEc2EzSm9WYWZWWkZNTTJnVGpLcGlmVHVGWHlOZmNVSC9OcGQyVnBCb2ZacGN1OTBucEp3LzJDMzlwRy9DYy94anpXd2xITnpYOE9VVHFZaTlHUGJZYi80UUFOTTR3bDcyaFJOcU1WdzNaYTdRSGlvTWI0Y2xxN0hqRlc0cHdJVVB6L1B3RjBWMERTNkVZRjFrY3E5WGV6NHBiNW1UQzFuZzNpbE8wOUtiV0w0REJYKyt6TVFSRnY2RjFjdTBmZHJMcWsvV3Y1bFpnMWk1WXNONjNlbzNoVVBWdmEzSVIraWNrVWQvbjVwbEtXSmRlc0ZBRzdyejB6V1ByMFFYbFVxK2ZtSS95TVFFSXlLYUJaNWNURm11Z2ZEa2VocXJYbTVNQ1NWL2JRRmhIRWpCdURtbUNOMWwvOGR3TjRjcmZxODVMZ0NmK3NEMWgxSm1CTEpMZkRFcUVFS0c1RDVxNmJGSGM2QVZLZ2JqVDBGOFcrb2pjbjZFSXdXVlg2bEQyWm96alFncTN1eVVNeEFrMHEvNkxIRklUTUhqQjVuYlRaYTVTZmZYZTY1QkhpYTNpRlQzNWhOd2kweTlQdTY1NnByTUJSWEJld1FVQkZJbVRYckNoNGFDb3o0ck5KTW9RZkpUTG12MnN1YVZuMDRoL1R5THZ3UlZSSktSN0grd25oamY3MEJIOFVlQUFtUXFCYWJLT3I2ZTM5ZlBxVUFJaHRjNWRhOUJRendmTWZTeEMzNW50emdwSWlPbnNSUjBFOTlVRU9Lc21kcXc2U0dKWUJ0MHA1TVFwQjBCaXE5clJtY011ZFkzSDVNSlBaMGIvcW9iaU55eE16V2dITCt3d2hveVJkR1dWdmwxcUwrb0xKaThndDZzaXppTEQ3eDhWV0FxNWVIdFJBWGpxbE54ekFnRVd6Z01tQmQ4ZTVMMXkvRlJwNlYxR2tUSTFJckt3eTVxSmtkMEEzZWJ4eVpHb08xL1dEYlphQ3BpNHlBaDZISTBkZHd2K29KbG9iVmR3M1orN1BXbm8yYzRWbGpWRCs0akZUc3IrSHlvOWZBRFNiQUdmVVV4bFJnQ3ZyS054a0lmM1d5RzhnQ2Y3amd3K1Nac3BnV0tjV2VHRlhjVXZ1ZzhlbnRiSk5JNVVJK3NJYmd6NUM5NGU5Z2l2clNsT1R0b1ZkMjVkQ1NmVjBEOXhJN1M1NXFIZU45ZnhpVWJvK1ZjSThlVUEvejV6TUFOZWhLN3djN0JkWXFmR01SM1JOMnFVZXdsVktYT3RScEtoUjEySXF3emRHRjNnUThFVnhiSWd1YWZ2QkhyU3d4M1RTd3lNRHgxYTRoRXNCbjZKUGNYUVhYdFhxeHpuZjYzSmJ1SEpDaDVzMHVQZU1oVU1sWTB1YS8wRjQrZ0U1MkJVY2ZDTXhiK2RZWWo3RDFVNnZsWkVLem91VW1MRXFZaDBuWVBSQ0JDNDk4L0UrK04vV0RRbGhVWjdhSi9oR2tmN282MVdLYnpKbGZQSmJVQkp0ZzVNb2xjbGpxc29HTHZwT3FCbTl2aStGalA3aEtXdGc4WXdJOEREd0E1a0VqUE53SGM4dXBpVnZoL1hocVZTSHhOVDkzVFhXRG9iVjEvV20xYU1lUHhxc3ovY1kyMUxBcDRBdWFJYnV0RlViODdkVFA0OURrcWZpYW94Qm8wSEcyZ3J0NjV0SVNkOHpIYXdzWE9zb0c4UlFHcXY2eWFCakF4MExtMnVuSWxuQ0I3cnQ1bC8xeTN5UDlHTDFkSFYvMkhkaFRmTWppelBUY2NyZGxOcEhkVlRlRTN3SXlrK2JZNlFlZjBPbXNsWUprOEIxMzhhK3kxVmI0YUwvVGtVTEtpUHZEYmpGaVllaERTalpWM0JNUktpaW04ZEljYURCRWZFMFhMQUdtNUhNZmw3Q3g0RHNMdjA5aWhiTlc5a3JoSWRQTnhEQjNjR1FJR05QZWpyZFNBbGlpRnpxQUFMTVNMeW1LNDJKT0ZoZ3dodkxnZTRXNTh3dHBtRWo5cFduWkdjellkQTUrOGRMT2g2MEJVckZheGhGME81bFFrU3QzczBCZ3dJRHlsVTJHRjdoS0RWVjZpWEdwUEpIZUsrckdvalNTV1hoekg3Rkk0RmliQ2JNVXdJVE12MzJzamk2Z1I3dm1RVExWRVlDQnp4VlNyNkV3WVFzRGRDRnoyR292OCt3dlVGMm5ydnJxbGRERDIwakYrRGtMTU8zamliOGYvb3N0cCtKOVd2N0g0L3l4bmZWK2FWRC92ZTY2akNkWjVvKzY1cTZ5OXhNcHJDQUMra3BibHhhMTJvck9YTlhySVNRUllyemYwNlVxZkpmbXVVMzRTZnJtUEhlbFFTczNyTXNHS2ZEeWtrZ1paRmV5RVRLd3ZhL2htOEd6YmJHMUNTUmRzQnVSNlEvcmN3U0duU1FUYlZEc2hhb2Q2MDFmNmJNaS9JWkNFS3NlbEdGSEd2cllHNW5jMHlrU2tqUVREYSt3T0ZDMDJUdnNQSXB3bDMvWEowZmtPL3VCb1hZdDZKNjFXS3ludy91NUwrcHd6NDZnVGxuTEZYQzJKMFBVT0w3aGZtZjRxa3o4dm9NMDZ0MG93eVR2amhkejdDVlBUQVZFYWplcm1oM0RvNWk3VktwQVg0Z1Z0cldiSk5BcDhSVVk2TjNDeDNGd00yRHE2N2luS1BnVmdLUWlyc2dGK0NuakJHVDd6SXJnaXNTU1djWnRIUEthTCtuQkczR2ZIaGpTd3NjWmpoUEFJdkcyYkZyNkF0T0xRTGp2WmdCbEhjcVhCdzVnak5XWkx4TWY3QVNXOXNuOUJIRE1NRUxOdDVFZ0tPQlVSY1lhTXNCNjRLRSs4Mk1aVkZLdjBPSzJGVWdpdHh6NldNd09MbDAyRk40V2hFWVg4T2Y3MFJPR0h1WVM1aWlZT2FNeGZpTWVFdSthOWZCK0JmUDFNRnRIZStOSUFnT1dDSDlKUFFHUXlXUEN4NnpRZDlqRWpJNVc1WmErM01MMm4yMW9GclhYUTRHQzZMVSszTGlHS01KcG9sK2tmN29zNjRJcnZnWXd3TUVKWmE2Rm5xckFxbnl5MTViNWQyaFcyd2FzM2V1dlNNaldKWFhzSlF2cEw2WUdtejlyaHNIaU45enVRa2RiRFlrSDNkZ2tzWUR3R1M3clAvVkk3bUtwRzc2VUlBWm9BRk1qQ0Y1OHl5YktMNXNRWWVFcER6NHZhWlBVVWVKVnBYMkl0RkFJbWgwYUhla1ZnSWJLVXg3RTBKL0RnK0NqOXB3MzVZQjIrZUdVcllTMWQvaldtZHJrZkZUVFZLUWc1TUR3dURXSjhCVkhQbjN1TXpwWGhTc1BmdEZMUVpUZkpGZ2EvV0xRMW1QZ3pYdGpMVUkweXplZExQcE5xR3JYMUFPc05obklibG5iaUZ2aERvK0JMNTR5S1R2a3pmNEpOTmxaTklnSCtYb3RjeDFudGZjTkFrV3U3TlN1NEJOdzV6dDV6TStWdG1CYUtrOHhycnUzM3NqK1hWdWRqOVZUckZjbzd4NUUvakJmTFRVa2hNSTd5VERyaFZ3R08vMUJsbVhHSFQ5cU9hR2VubUg1a3oxblYrZERtL2s3S2g5Ry9LMmgyczZxZUxzeEhBclJiV2hJQUdJcExDQzlSU2xGUDFCNisyRVNpMlhKM2VmeDhNY0ZsWElaVEtWN1hGUmw3K2MxRnZoMnF2TUNjVzhvVmlsUWtuTHJZNGYvb0dOVzZ3OTg1eXRLY1dpK1NQU0UyaE9oREFVdCsxTHJCWGJzbFpJYTBBUVhNVXAwMFprNmY2Y20wZGUzNm5SYlFWTVBQcW9YRktVV0VFb29rbFlBMUM3Y1RJU1haV256RnB3ZHo0SHVZUjZ6RWVmMEt6c2tnTjNBU0xjbm9xTzhUMlFBRnNzalJJZis2eGg0RVJlYlZFdFF5aHpTNVdzQ1JrR0JGZlFXVlAzaUVwKzI5bFhDMXl1OXp0bGE0Mytoc2I3UWpvUmZYTDZTb0lsSnB4eXl4T2U1WU1iOFpKK0d4S09Nd1FhZWNISzl4bFNTSXE5UWpQR0hhbGMwR2ttaFhVbjBMR2R1UWJidTRRdktLN21iUjRZMXBqdnVBcWg3emRNSVV6TmlEamZUeE5XUENuYURFaFA2aEEyVjlvN2ZPeUVVT1haMmZSV2hpOFdzbjRUVTlvSEIrbFU3UjZDNVdSMm9UMWxiNllBNElDbVpSWDhGZDhtQklRNUZUMGxkR3pBMWNPWElWekFlYTBPNGU4S3lSMmJ2VHF5aDh5dzhNeExLdHZXMy9RVW1ESkdZbzVFSzJMdTZIWVkvWldwYU5uRmRJbjlqbkd0YW9DbHhTdjJwSHFTTEFBUEJTUVBOSWtLTnduN0ZhZHJWTW8wOUNQQ2szZTVNNnhiVGxpNzJYZzlwQi9ncGg2YTVQSTNhWS9RaHVoMEt6dmZSeklETFhMZWNIcE1RTzJMKzJNUHl6MVpFWHluV1pFd29BQk14OXYyNUI1bERYc0xmUWd4MDFFdEZHTmc0aFFmUENNMTREUU5EbE1TZkJKcnN6RlFoODRydmxEb2Z0NjN1SzlwdmlOVTBwWUp0b2VWQUJZVWFnYnM0UEgwb0NWN0VHSUNWNGtUQ2J5QXdZRzdWS3RQVzVSTlBnVmtSNXpVNERXR3lFSXdhdFhNNWxFOEloWWdGYmx0Y296TlJ5ZEVMMWY4b3hoMGVBdG5uMjBtT3BTQVJqVmExWGRGSnR0OWt5ZEkwK2JxYjRMRWgzeEJxWWd4dTEwMnlSakxaeU1Ja2VmRTFrS2NGbUwzaWc0SkF0RmVQWmF1azdvemxsbjRpM0IyaWNHZEVNcVJ4UHRWVjZyRmZCUTQ5WmNzcFg2d0x0aW1FZ0dsMVp0MjlpUk1IRW1TYXk1NFBRL2ZhMHdMRzYwcmp3VjExd0t0QVFBc1FCUGd2a1NwVDRCdHZKUGdpSm8ydURsRHpaWlAyL0FVWWhlQ1htYW0ydm5xZWsyclVkSitkUHhRck44RTdjaTFHYWN6MzRPS3dlOXJ6S1hOZzVRSU1UeG5mVEFJL0NGekZxUVFmQ00rQkt5dTBJTEVLcXZ6NmI3c2pOWXlINTlramtIN2FEWEZkWmFuTDI2QzFjNVJOQk5vL1dwOVBjY1h1VEUwMzBFKzA0bzZoNldGNWNQaXBuRE5ZdVJHT2UwOHk3Q3hYUzk0OEN0MDdhTm50NDlxSGtOSEJJQy9BZEovN0UyNHUvc0hmTXJDV3pMMVdud3lqUXFpa004MjkxdERsYjdqYit0amxOTEp3bkdwK1Rvay9xVmhZdWxoWUF2WkVhZTYyZHVBQ0ZMZDV1UDNZSWdPYWNxcGxGZ1p4c3pnVE02Q1FnTWI5aFNCb1pPcERSOFZjYktleFVaVDNOYjZCeGxpWEx1QWxkb05Vd1VXK29MNVJ2dXFuaWtTQWNoY1lTNjhFZXgzWWdqNlFGTHVpVGxYbnJTMVJGbEJ0VlZPMHk5OXJGU0luZFNreW5VVlhOL1cvNmdHZFV1YjhOcGRBS2s5cTg4cE9lZnQwcmMzaE9DVmdGOVI4ckptZWRGUkZoaTY4aktNNFpKMzJRSzUxNUVZTC9valRwM0l3WVJER2d6V2NtOUY4ODZrYkZDN1NmQlorMmo2enZjMzdDNldUQVZhRDZyS0prUjkyNlZ3aHhSMGVQbnVjMDh4MWUvY2xTUDIxOTJaNmxhVHVvTGhhcDQzaVpzTStrUTdEcGFpVCs0TnlHekNJNmllZVozZGtoeGFYR25rUE9EL0xSZjJDWVNpbUg3ejJ5MFB5S1lJY1hBK3RoWmpuSFh6Y3U3dTRxb3N4UTRLUnFheW5wWUpPNjA0TnV1dlc0WHZPd0VhTGcrZDlFdW1xL29aQVZrTk5iajJJUVFGN1hYYzZTQlRZUExZZVd5V1N0VlNoK0lCRUE1dGw5MDY1WWdBelNOTDNjc2R2WGh5emI4ZEttMHFIa282RzhSeVRxUnNVTkRHdktKVmE1bCtjZzRkYnl6M0hjamZzalpYOENuemQwNjFVU2VBQTgrU2wyVFJoYTg5ckVZWnRqZzRZdHJibGNXNEVtamd1UThYQ2ZwdnNpS3NLcnF5RjFBU1Iya1ROQTJCRGpUYkxnWHpEM1h5aFc5K3VPdjVEMzdiWjZZRkl2NG5BVEhqcEo4NFIwMmdudDBPL0VGUHpjMHVHOWZaK2tCWGpUcHduc255RHNEQ2J5VG8yYTJuM0J5cFdKOU9kZWlUMGFiSTlBZXNUOEk5SzFiNjludlpmejJ2RWRrOTJGeTMzNlVTMmwvL0c4eVlvQTlncEpjbmlTbjkva0c4bVJyVXJyTzY1VUlrYnN0dE9ONkJ1MmIzTTJHQzNINTlXSXlFSSswcmswWDMyN0RrWS9tY1BOcVk0S3ZMNHBNQWgzWFRLZDltR3U1cWpITkZqVHBJblgxbmZscHZPSlZmS01xcUk1Rm5TUGRKcGVSenFTR3liMGQ5WUZMc285K1ErclZPMHhTUUdPa3FEcStEL3NjL3RzK1dHSjJvS0dTWVVRMjFMUSttWkRsN1JIdkh4QWdtUzl6MnRTQ0NnUUhCZG5ZMEk4WXJlOHNTQjFCNm1RUHBod2lSZHVJSmYvSHJXTFBDU0loTjJGRUg1L0tMdCtZbVNmckQzNi9EWmpPUWxYSG0rU001cmRXKzA5YjdLOXd5eDBteHRvUlpZak1NWXEwVDUyb3VQMVFUQ29wcDRPMjBPcnBHaWF0MXNaRmNrTWUyMXUvelhwWGI1UFEyVkFhVzczTHRBT2hIS2hkRWd3VGMzZzNHWlFMeVdNbWY1elRCS1Y5TVpDNGl3Yk1CYWxzc0FXcFZRVmsxVkdJNXpzZzljaWp5SWpZc0lSaURSempOSmtxMEpxeU42WVBFcWYvN1dSdE0vZlp2Y1hNTkVuVm1TQTV1T3EydWxOamhyTDEzenhjaUU1aXAzUHpNVWpyeWEycm5Oc2h4bnpPc0pnV3ZTZWpUMWU4NFplTHdEa2tzOGE1U1Vkd2lSM0J5V2hpVjgwTFZJVFpST0duU0pDemVzeFJoR0pwR2ljNUs1ZGlKTUUvcUN3SGJaVmpQN1dyWFJQL0VoVjFCbVYya3R0bnU2aVE4aFJaays2bXB0dVpGa3I5V29sV3dSaHpNYXRhbThMMS9PNVFrNHQzS0owcjFiVFVTcXNkYXpDZ1RNaW55RnhEeHI0WEhpb2xVdzZOczRaTUMxZ1FCcW91ZFNJcXFDdFdwcTlWdG1mRjNvY0daNjBBT3FBS0JWNHJScGp3aEhhQXpYNHhTRkc1M1dFTTUxbEZWM2x0ZU5nZStVWW1tWDV2dDlZVW8xeUZBTEFaR2ZWOXc2WUNubGxBenV5eU1uSjNncUhZTW1NekZjR0Vab1hzZUxaYUY2VTRubSt0Rk1mVi9sVGpGNnJTb3ZTeG41aFkyMFpIdGtpMGp0WE90bEJVNmJsZTlHVEVjRmFXWmxYY3pSd1hJSkpzNXI3Q2daeVdnVzhJVnB5cFJGZHViKzdoY2xPM2IxWkcvbDE3bDUvMng4OFRXakNscE9NNVUxb0ZNaTdZQ21BVHZzcUdISkphNjlDQXJOcC8rTlVxWW5FclJ4NFFXSlc1SldUTmFndmdSdGZ0YkNSOVlyckFSVnVjSVFLaVE5K1cvOERlN3EyV2hkaXkyeXVrNlpwc0lOTk9nYm9oclNKSnI0MzU2ZE9tdWcvakRCZmF2QTYxTWIxTzdpcEJCZkVxRGkxZUQ2eW84R3ROU2R5ODIwWVRMZlUxWS9DazRoSVk1Y2FGaTFiTXhOVERWSUcwUWNGV3dvc2t1dHhXTkJCcjl1bmN1U3BLS25iT2s5U25ucURkWGhmTThtMnVJaHFSeEh3R0JPTVRmd25qSmdYWmRibFErUXFrTkNJTWRlWUs5V25OWCtjZjdvazZWaHp5Vjh0NVhqY085UTJMdUtBRTJzOFRmdndqSmhUbkt6OEUzVnZ1RzIvamxIVW9jc2VCczZvdnFYa3Znb0ZBMjNxeUhJeHFQU3ZFeVFOaG5HZ0dxRXFpMHBZNjVXRTE4ZGh4ZTI1WE5wdTZibEluNVU2VFc4MUFsTmowOHZwNlV2V3lyT2pyZ25rZU4wb2FtWElzRENGcWJxaDMyQjRWZWx5cVd6WlFGdXNxZEV5QmlhL3VXYUI0dFdvVTNIZkQxOXRMZUh6Y1FMNG9VVTRXS1dFeTFZNnRLbkZUd2NrYlBOQzZvc0ZLRkdjQzVDdERTMllWTVJIVFAybUVTLzhvTk9WSkh4YStkTmdJSjZEcWxaWTc3ZjBqR1ZIQ0hHd3V5bXpKZWJWVHZhU1E0VFBTcStMWXJhMFNKZE1sbk9HNFJlZFV4TVBjaCswdSsyTENDYTREaDJscVcxVU85RFJGeFZvMXVxcTRWVWhreExiUnEyMDNSSUVjZUgzN01Oa0pjMCtoZ3g4eWRGT1ZWYmlXTHA3QTJCbEhmeS9BRWoxNnNhZUpzK1cvNEtmTWpXYjZNMkFpeDRVTkZMTVpCZnNrdU83Y29UVkZ0emZNKzlxUTJLSGUrL1BwdEQ2c1g1cXhZMVFJODhJZXB3YTRYbGVXc0RRWXpuNjRwNDVzSGY0TlRuQlRaMFliOTFxTEhnV2lNY2NZRlZSTlB2ZElaQjVYVFdxN0RwMkhoclFWRmhXZGtaTnJaNU1yaUxLTk9QTHdtMmMzblVWS3RlT3BLZkJNVHFMSFFzVmZRSnIxSkh5UmZRMUZIb1pjVVNLVW1QMG9mYVJQQ1RiTy80NS9zUDRNRnlyYll0ak05dlRsU3pxYUxmZHVUNEpWQWV0SWw3K0I4bDQyZkozb2VPTkNFOVczVE1ScHU4MERhdmJCTzMzTXkvV0ptcEw0akhma0RVbVdFQzVESzlpb3RtNnhnSzNrdHlLYUFsT2tEem1GUDRQUlZreXA1dzlFay96djh6S2F5VDdMSHlCNUFVdFdocThCZGs3MTNMTnJ3RTdCem5TejQ1TE8wSXpmKy9VeXpkU3BnQVMrU3NRd0l3eXp1azNFbkxYanAvSmh6R2V2KzAzdTRJYzRDUnNJQ04zblpBbUk3MHE0NzZ0M2lKN3RTZk1UUFRPeFRaN29sMTROdndVcGd3VVhWVGtGSCtueXdMSXdwd21ZdmFtVDdmdjBCK25NcXBQdWx3bGRkTTJ2TTkvRXlKc01ZTU10K2I5VHNDYjg2THhINXM2SGlPZjI4SGZxSHhaTGI5T0hiNjg5ZU4vZlVEOVlRZzRGWFZKZmE3THVnS1V3WVk3amlzb01qL05uQ3VDREdwT0ZmclVaTTB2RWJ3cVo4RS9YVHNsOW53cnRrSjM0Z05CWS9aOUR4dXlnaFRtSU9PaThKQlNFQWw1akhvNHN0MjZIRVV2YUR0czEvUit0N1I2ZGJWS1VIeGJ2TmVsTTRZTjFMaHBrVDhzeEQ2amZrNS9OOTRDamVVd2lRMmdyc2dvSVlMa1Q2RzNEL0JBUzErZHpNYkVJSExnUGdIMDFDR3NVRzVmU3hzTmJFUUZ2L01jK09LcUFOVGtTamFZMnJtakpvaXd3cHhuQnpJMGtSOUtnT294TXBGUkJoUmF0RU14NGxUWmR1NlpqWlFmNC9MZkg2Z2REWTR1dFNTc2ZIZHJBMnFmVDRGczRBVmNRY3VZRStlVE9UWXBncmJ3ZTVBSTV6cGs5RHo1QkgrQS84VUZpazdzeStSOG8rUmwycTloblJUdVVQdi9qbFREbDNwcUp3UjlkTEFuYUhZMW5ValNScWtvUlFkdzlVMGp1NTJ2eUNRV2hwSkw1bFh3YU5xWlAxOHpXMWNYbG9WRWpjcmV2cnQyUFlTcno5bkNYNVk5YzlxM1lnR25xUXBQRW40TlE4WGNLTzdoOGdEMW1DaHB2K2l2NC9XNXZkek1RRDdONzdqYXRhZDVLNkUxdDdsU2JMWTNWY05EM0Y3eENYWExGSjBmeFFzcnRIdGNad1ZrbnBaQkxmUng4dTFza1lvS3hzb21ac29xK2c1SHYyRW5ZNGR5SzZQQnJ3MnNnYzhMNnE1WTdqaldTaXVibTZNa2lSZ0t4Q056Yis3MkhyRmRvSVhsbUI0RFIrRFo5VUtnbk1HdXprLzZMcitLSlZ0U01LdjNRRVJlL29QR3VJSER3aDFhNE91RUg0eERRa1ZLb2wvY1lQMFFvSjlvR2Q5VTE5NUp6dnYzY002ZStpVHJQRmZzYTIxU1RpL21LSE5TUGFDU0RFMHQ1bmxGRmsrUk5jVHMrNXJNNS9RRVA0Y0wvMGFnNlJZeFV4dHhXU1lxYlp6SVR5YXoyZ052aURoSlU4QjB3Mm9pVTJkeVZSZUMyYzBveGV1UWZFM1FBcG5WODI0dFNYdzk1WFk1YXIvcTNPNFcvd0FSbWp0Qmx2ZzhrNDVuU1hNSmN4d2xxV0llQ3pJSFlSU1R3V0Z0ZjcwTEZBWEpiK2hObEV1ekg4S1lBbWlTanUrQjdmcGxPWUJWUzUwV2dmTmtSTVhVWGFSelhQWEIvTmZFSElUR2dQMGJaSm5MakRCSnZaeEt3T0p3dCszSW1BVEpjWC9BM2NiQVdjNUVEWjNnMDRqb3J5OUY5a1E4djR1WDN0OUJqdWZVdDBkMHlya0lpUWMwVVkrWE1kV0paZlZrc2x3cFk3OEpzV044TnRtNzVvdEIvaTJ5ZUw5NCtlZFI4YWdxeVNJZW1MMjlpbDdqbjV2SjFNWXVkSUFOc0NucXRHMG5GOGJqQ3d4VG1ieXpqVDNlSG9uWWlsdFNvU3ZpU01aeEZKMHBZV1BOZW9OWW1ranlKRm9lQzdHZVhNSTdCakJCZGNHZlJOQXpSeXZEcGtoSzZBZWNBM1lVcG9GQzJXR3pYTkhKZzd6VEFxaUpQUm9vbi9ZcDZBeVdjRWltanI0bHMybnhxYjlPMUpncjRGNkZnQUFDOTQ5K0EwUXJ2dW9jSHJhSVNGaDhFYnIvdDF5cmhmMEJScVo2Y0FoME5DQzFaek9YeGJ4bWJGVlRLYXN2c2NhL0ZRalhud0UzUFh3UXVCc0Q0YjNlS2M5dGNJMElEcmJDbEMwUkdSdlhqaW1adGRQZ3JLVlh4V0ZnMXgxWUl1K1pJVnJ5Z0plaUZJMzdwWWNvTDBvUEZkVVU3TCsyYzl0SU9jRmh3S0Q4R2ZTa3lpMjNoUGdEY1dJUEhTTDVYKzZwRnNrSzJjVmZON3BWN3VhYm85czJVWlREbnNyNGc5cjJnSFdwUWthUnEvVFNXREp1YVhwcEVXMEN4ck5PUWNhK3hLTEhKWU1JQzdsVjlmMXZiUDZhNGsvNmJ2c2FFRXc0SDRRODMxM0g4VlVYanZWa3pJVWsydmZVSFFkNFB3Z01hNzdiWlFYYUlvNkJJcSttWDYyenp0T2M5OVp6Z2tPbE9LeVNIT0lTdFltL1NpL3J3OGVGR3B1SU83NTZuZ2djSEdUZ3RYZEZSYWJPVFBvU0lOT3Jsb1A2aDBSWVoxTXRUaWwvUWNKNTZJYzRoZ1ZCL2V1ZTdGNVR3blgrck5tcXpmc0F5MnF2U3JxRnRKaisxcHBEaXA0dEdrMGNwVEEvajRQdmllWW1LUlhiY0VZcXp6WHdpSFMzZHVac3ovaUFldE1JeTArRThBNzFLTEwvSmpZWEdTOGUzM3dLc05VcWkrNTJBRWlEOTBoZldjS09lTWpPSlNpNy9oaHByVDlBWU13OCtvQ2VueGRGcjJEK2pxTUcxTmZiUS9IZ3FoM2FJWW1MVGxJVnZSWEJWUHZ1cUdVMzNmLzkxTmNGMFZibHcyeG5zZHRkMzRLOVkzRHV1dTNtZEk0THBqRjlGSjhndURXZmtMN1RXRkRsUElZQnpIVjNtNzFjRlJMdWp6U2dJbFB6bGJGaDNtcmlSRlJRcVNmdmpYZXpQUzg2R3JvdXVBL3dWL3JlZlo0ZHdBMnd4emx6QUtnQ0pZbmMzd2txNGVibi8yQ1hnazlUUTl3bFZ2VTROU3FycXRNRHcxbm9DQVFSbFMrSU92OFpzVFd2K3NvM3NrYUZxZDA5aTc2eFFyUGpSK1JvdE9pVTRzY1dRSjY4Y1lQbWJkMnFEL2cyWDhVZlhMR3NWeElwbGdROFRkekJiaVppT2h5dE9jQ21seWJvVDU0TWVXbEhZd0dqTFk1Zyt2SFA1SXJHblJFOVNmSm1RajA0WlNSS3FINWw4Z1h1UDlHWDdhaTRCZnFlbFdKZ3FvaGFiNEFyemhiRG14Q3NBcnhaWDA0MXZwRnZMRjkxZHNRYWhQUStZU2U3MDRIWmhVYUhYUmZ6ZjdLUWVPdUxVMnJoWlM1a1plVkViNDdReGpIODk5WGluV1lmV1pveXExbHNaU1V6OUl2RXZPYVRqL0F3Ykp6Z2xUdlk1OHVPYU9hbnZ4VDZzSXI3bklCMVNrWmcvMkhhajVDZTBrUCtqcHVxVEk4ejcyY2Z4OHMwbU5rWk5aVG9ERGxxcnU5U241T3htSm5TUHZ6UlptdTJBQUZCZHhUK2dLNDhJOHh5aVFacTF3VCsrZjE2WmdvbVcxVG1vN1lIYnhOM2tCbmpWMUJFOENoTmo1dmV4cGdZbHdwRUgwNXJXbDEyZCsyRlJmK1NnWkhPbTNkZmpZVXRQZDRGVXFkWThJc3NXWmdsaWlJRjdyS2VJM04wZTAzc25uanlIMmRYTkFOU2ZkWVZUSGcwUjFoV0hqeWt6Q0JRdU1tQzhvMXVYUzNDMzJxM0I0Nm8zOVQwSEV5Tjc3eHBaZXR1V00vQU0zRkVzak9HaXNuL0k3cVd3bmoxbTBFNDlzWDVSL3NZOTE0eVJHOU5jaUwvME10QXBQem5vck9xeElHVC9aUkN5VlJNM3Y2OVc4SHRHVTVaODF2RlNNbmtpeW1oMzJnQTlrTmR5c2hadFBtNittR29TaHNaaU50eE1ZK3JEdWQ1TzFJeEpOR2o0UnpxNVptL0JRSEJ4NVMxRkJyWkhhc29DUjEzSGtxS0Y1Ukc5cnBCWFNQZm93ZjhyalBGNkNOdGRNR1hvWDAyRnllME0xWWY5TlJJR0lNZXFmYm4rdVBNU0pGcy90dXVWQkR6bk9nMU9TdnNLTS9GTm95c2dENjlMVElSeFQ2bXM3ZFdDOUFDZ3dSYWpkRHh0TW10dlFwL0dLSFBoZ3o5UHhZMklKTUNER29FZWlrVWZablcvZ0RKTE1ZOEZkY0ZudHhhcCswajNyNWxHR0pTdlU0eDVtbW14M2dtZG0wS21GbTdZZUw3VGZXUzhMa2ZPai81bFN2ckxtQytUTWtyV0R6a2h6Vmk4aFVEczB1MUhBUkRXT3JydlYzOUVvVysxektOTnlIWG1FMWhlcis3ckdCSEduL2pvVlJsTEMyaTdLOHJHb1ZaeWEvaHliMlpOWkRMNHlpR2NIakplaVphaENwTEdUUFVLdEhEMXh5aFJvUlpxbGdqdFFwVjkyNmtpK3hhck94UCtjMzVsNHk5eFA2NWppVGJaOG1zakttYVM4V3JRcEVkTFgwY0RqdzVFUVprTjJmVVU4Y1NDenlCY2dxNGUvSWZSUTVjZnlHYlJDTCs0N0tVYThxZnVlTTBrdjY1L2tIajlpVWhSbTNzUG1QbmxqVlRjL0xVQVQ1WTdzeTVRZm1WUUE1emJndE4yYUZmaDY2U1RjakhmNXJHNkZ6TTZ3QzF3dUJZcUVkNDBpV1BrZTMyemlEanhwYkM3ZDAraUVtdW5DYzZ2WWxPRHJFUk9JNnVUc2xsTUtzNFlMK3o5M0piSXJNRzFlV3JzSllHMEYxTEg5Q1hKbG5XbDJldXV2RlJhWmdPUGxVYyttZXZyV042RXNVdHdrMytZcGRhSERFT1dwa1lUQ3lyUGdhVkl2d1hWWjlIZkJRdnMzME45dVRCU3NjVmlOc1RXWFg0TDRLdDZQeHZZNzhRMFdQdEd3UmZaZ3ZiYUtsZ2haNjBQVmF6RytGK3NOaFU4UDJaTFFIdUc5RUhHRkR4ZXdLcndMa0dCaEpRaDlnNHhRTDJFT1VYa2UvR3FNeVV6SWdjck5NWGYvOVh1cUN6OVF3bEkwdlVYWEdVbWFQYmdwblVSOXYyYk1Qb1VxSVFWdjh5RnluRDRJb0owYjFLWTg5TEVpTEtCS2oyVEhJMWNITWhSeEtjMDY1QmdVaHNSTVJ5YnFPVVVrVzM4dWczM2xWZ3hjT2hSMGFOa213Ri96Sk92bVM2cUwvREpIQ014bkkxblJhUTNKUU4vVDIzUmtoRFpSSm1FajZhai9CUGV1THZ2K1hxampiNWozbHc2cnBDYlI5WDdxTkpSNkVhNmpQd1JDeTU5ZXBiV0hadHpYeWF1NVJpeEtNK3kyWkFhUDVHajlqeThsSG1VcXRNOVBhMkZHRzNGbkpFWCs0NXJROWZnRFNXaWZIMUJFTm83eXBzeVB4bDFLbkFPQ0VnczliNFIrTkRPWFVhUloxQkh3bUNGWk1KVkxwWFVoaFFOMEFxOVRaOFBoalNYc3ZWN2FLSHlXN05oekpzbml0S05vZzEwbmp6SGZvVXdEOGhUM3k3YjBMMHo5NUhXWFNpaUNGSTYvd2Z6V1hKSmxkZkpuenFkNjM4VWJ5VklrZzBSTVpNeWQzb1huLy9YQXV4RXFBaHp6VEhNVG1scUN4ZzFqNkN0Z1BwSWJNMUVPNTlHV3kvM3pSMFJXbGNoY3RWRTlaRWFYRm1XTGtrcitUTTFKUkYvdTRkbHJqVWMzbVhXTmpPWHJIYk9rSU1uYUVGd3E2RFZGYjh0Qmk1UWxocllTWFE4WFF5OUVzRXpmdG83cVBDeVpCVkxXb3JZMllYVlBIOHJqQzloemoxUmFHdG9kNVRYTTlFYXpnQUV4VHk5VDJyN2ZrSmJ6YmVDaGNtK1hBbEZsbVJMNHVzT2FlL3pLbDRvUnJveXdoQ2RIcTRnL3FjOThwQm1ucHZEU2JjVGtucHJNcjArNlU3RVg3V0dXTTdmbW9JQjNodS8xcjF2RklFSCtWMUQ1UGFESXl4NDh4bVF1Zko2YXBrV0wwc2EwMmRWNm02YWxjNjYxdXpWZUtyQW9JSklCRzRaL1BONnVjK1JUVDVUUmZ6VUhZa0hoT0Q3V2Vub1d4ZVg4V3RUVEozczNOdW9jbWREbjUwLzYvTk9zTktaT1ZUNnpjUmh5VjNxRGczVUJucmZUVDMxakJ4azBXaHU1dkJXeDEvS1Z6b3FIYjVVcFVlZk55QjRhTGdONjlUVzRWandOMGRCc0Q4ZDZuZldpampzaU1KamYySmNvMzA2V1grdlZyM1JDdGJXWFAvUmRsWWJYWTJQUFQvZkRyN3NtNCtuZkV1NEZENHhGTHorWXlENHIvVG1lUzJzaE8wemNMZmkzTWt0UzdNdGNYaUFOR21Ud0FKdklLbUNPd1dobGtTamlNdVRjSjRrYlI4TytQYjBtUGRmcGoyMm5UbmF3NnZJU0thMUNTOGEzTzZkYTdwaUg4KzVjKzhNREJpdmJNNEZQUFFEbjBNUHVQZHJoTEdCRElwYndUK0I4cUpiaCtCcHlGMkhWYWg0U002M3RyYlJjOFZicG1OcC81b3dReTVwVHpKMkxZYTV6c2Zra1RRcGw3NVcwbTZBbUYrOHFaMFZzRDBzT0FqSUw1cnIrcXR3aUxkaFBxQjQvNGUzYll6TkxWSU1wY01ua1JhS0RZcHBHRFVTdk1PRHFkaExGN0owcWNvMjJZZXh2OS9odGFHNEdXQjk1OCtHVG5JOWdNc2RzeDlWVkNKNm5GZDJ2M3VqYmg3N0VCbXJjZkhqdVkvM0I1S2ptaTB0dGNPdWUyb0FmR2VxaEpXdjB1VEE3NVZxYSs1UmxhKy9tUUUwSU1Nek83TG5YaGlsYzJQTm1kdG1oQnE5cEsvelRYaXo1cHZ6b0xWUTIxOUVGb1JFVHUzd2h0aXF3MzJ3QXFVMm1jazgrUnFtN3FTbnpmSlhWOG53TE4zUWhqSTRnbHRleUR5QzVMRHpCOFU4Ykcxd3NSSlUrNzdmeDdDa29KVVpxZXdCWDUwcGlmZDB2c0pjMktLV21iU2svNjRweEdqTFlNaGtzUnhRR1VYQmlJUlFHM20rQ0Fhb2pleHRaVnVPb2wwRlZEbFZoUDNBeTUzdjUvS214eUZ0ZXN6Sndha0ljZTVEd1dkY1ZXdk1TaXpxcEd3Mnc0QXVKTEloZ0JzRERKUEZhY2FBQllYblJhbWpZWHZXaDlLQUNFMFViWlBFajdsaVYxZzRFWkNrL2QvRzJXbVBJeTZHUzlsV0FCM2FhMVpBUDc0MVNWSkJZeFIwRnUxQjQ4b29Obkg3OStUMTVuSWxNM0pqSllaUW5Nc1VDeFdGM1JhSXg4cHZqNmx2S0J1S2xSaVZCZjYva1RMb3FIZ3ZGTHE2ekhrRVc4QTkyRURBSzZkc1NqK254dUVscWhveUpaZStyV2dWRk1MY1NWUE1EL2J3TUQrckVRUytzSDg4Ni9SY29yTVhMbjFxclprMy9UUWkwV3RFaWhtY0ovWmdnbzNwejdQNG94NG80OXFaT0hVSHFRZ3ducnIwcngzV1doN2xiZmZLV1lCd1Z3bWpmemd1V1N5VGg2NVVtNmNyc242ajdkK0hGeHRLWXVmVzVyT3VUYWR6RHpXcnhKbEYvUGhjZVNzOTFZNFFneTVTTHBGVytjUHlLM3lCODRnbGZFcEJWVDR2N0loN2E2bzNmd0lBMzV3Y1krZ281YmJQaFNmRjhkTHVhZ3pDVmVmWFBHTG1JUTNTVFBxRDNpLytORXlseG4wOXVGYkQ4QlZzQ2RPRXhwYmdIU0ZHOXhSaGZZTHhpeEU0RURqbGlZNTloNGVUWlpMUmkyUFAvUmRYTUNNdDV0MEZBOUdrWFVnRmlvbzljOWJTdWU5djA3Uk90ZTc1amFHSi9zeFdWT2dFZTVqTEM5Lys1enRpNEZ5WlkyY1RhL0dVc1Q5K2thanRyVzFFeWpYWnoxemwwcnZzMHJwU0NQZTh0NEJmK0ZMcDcrNDdtMU9OTE43V0czc2lMVjdreXZUYXFwYmtiMURxZ2hyOHhSdEpBMnZjeUFXMHY1dXlSeW4zQW5tNXBPQUJ6VEtXR2dIQkJvZElzVXNJU1Q5NEl0M0Z4Ylh5eWVTbXFtYkxIQTB5MklURTV5akx0SDVZWXdMMC8zMGxmbXEvcGJFejl6RmxsRURNUStyTEUvcS9MWXFaRUlaSVdlSUM1eXpGSGdReHB6QW43b0lhY252blBTekNmQmpGbGM5Z2M5Z0FTRmdBdkowOFNuZk5OVHZ5UkhVMlZTQ1BiZTllNUl0a0Qzejc1NFlCaGsrSjRPSlpHa0l3VnpGODdmWnRkTnJaQmVOUzUvUlJrRnFUVjRtbmpCK05zYllJcnQyNDdCWk1xUzA2MHkrUytrNitFQlI3bUFVOW4xVy9sbmdQVVF6VEMxdVNpK2xlOS9DcDBCT0Z3OC92SlV0eWJmTkxsM1RvckdBOUhVKzhmOE1DV2NmejBrdDd0a3V6QUR2SWt0OWpST2dXYUQwbjM5Y1I4WVp6TC82S0NYczNnN1kyWFhWZzE5ckhTZ3I4dDhHTCs1Y2EzMERtTG1ZN0lVWWVzQ1BxTlhQaVNqam5xWVJrMzdxeVNoS05uNVNDUFR3dUxxQ1ZtUkxxa1l0OFFrc3owZzlFYUZsazd1OHBiSlFZR0tybi9NK0VBbW9aRjNhZWN5NCtkRHNCZy9iNEZSTjRoUWNwSGJvNE5XVW1sRllHOG5jSEFqV3RQRXVVSlBrM2hUVm9aNVppbU4xUXFmL0lEckg0aTN0SlRqVXM2MmhEeWRoRVc3ZkdkWnNjWlRGNnByUWt1dkZ4cnFtaVNqenlLTHVhRFpiUVRiVFExdzlzbzNVQldLYitXMERXazQzWmRTVk5xcmFCa0ZrT1VmSW1IQk5xbm5lUFdFVHFBZEllbjlsc05XMUpZOTNTUi92cVlkV1ZJaWFHVjNvQkNBcXlUWXp2cUJObzZqZXdXK1p6V3hwdkJ6S1llUHFLd3dEMXJlRWVzL0VwamhHVFVzQ0tUVmNvemx6RzhVVmU0M0V5dGQ5WC9HVzN3MGF4YUoyek9VS0J3RjlZM1hnTWd4TlRHdXpUdE9KQUZKaXMwVnQ3cDY1M1RremE4VkF0b0tielE0SzhDWEFWRzFWbnRBVDFCemdwM3l5R0RGM2ZGUllrWDFHdG53OG43ZS9abGdObDBZY1FpYTVsNUxMYXN2ek42MlEwNVhyZFFMSjVwTi80SkQ0MTFIYmpWQzJEOE9heG1nY01aSlRSL1pTVi83SysyaFcrQkxTOGNLSlBGQXN6cFM3MlpScjJTMGxNSFVnRXpER08waWxHVW54S2dYNjVyL2tNZkorTUtUdk83NTZzQkFTVW5wdEd2b0FEUzV0aWNiZkZOZ3MvdXByK3RQcW5ZMk1leFBFQlhyWWlzeUZvNEVJVnhIYUZKT1ZVTTlLdUdUVkpXZEphTEVXS3N2aGJYdzl4S1o3eER6dXpteGxCWmt1OGhmbk0xa2dFbWU3ZnFmMDhBWUx6eFJDc2t5UVM2TTFYOCs3UTdBVUVYSzlDbVc0eGV6aC9KOHVWQWtSdE8vQXlkYUpiYWNkSlQxL3ZJeitBWVI0a2dsSmhHVmdjTklENWFwZGxWOXhrVy9qbmRtVXBFTWZDZnFEL1B1bGdSdDEyUCs2SUxRbUhxSjJlSDAycjNocHlNa3JPd0VDZk5YYmV5ekQ1REdPVFZrc2FGeHpFa2RkTkVEZGdrZHdIN1lmd25tWVlhaUtpQ2c2ZnkveVJ0MlU3L3FKM1pIaVNzOUx3RFZ5d3NGaU1XT2pqYkxEck5Fc0NKc2tud2ptT2FOT01vazRjd1J6aFg5QkFZTzFQaWhqaTFkMkQrb3VrTkNVZGlIY1kzREdzUms4bm16SjVROW11MDJPckNOMk9aVlBQakJzOGxKd01xWFcyOW15ZDZWbTY4SEhZUTZvcDRtNENHaFNSVW1XVTdhdGJSK1pScXg4UXdOWG5GSkNFS3J5UjVpVWllVEVrTFM2MjN3ajlQblpwTEhhUVlGNFFzRHhZM21BUm5JZDB6MFI3WGJrWTR0MHdCNzl5S1BkNnMrSHJGQk9taHNCSkRIbDdPOEF5MW1YTkxySWxyS2toWkttUTYxVE43YU1yWU5nR1VucHNka1VUaXRHOFdpNkVFRnZDWGU3bUVONkJpdnlRQkhIS1AzOGJqdTdib3U1UWpHLzJjNEhiWm85U3ZvTG94cXR4SzFaZUp2ajM2NjQ4dXJiT1pPY0hxMW1nZnFjdk9mTWVmQTRiNWc3TWIrK0VGNkxKeWlWQ2JnZVJjMWxsNVlndDBXOTZyOVk5K3BSQXA2d0JTRmNkTFdYVy83dmhNMjFEMlNWdHdxTG1LT2ppSkNIeGNBV1VNSDBFRDdQUGwzRFhJYlYrMW90VmVWSVpmbkFTWFh4Q1VyUmJXT0pPSE9sb1ljYnZRc01KWVhsUXM0emZPcjdRWjg4endycTJoUGVlS0h1b3lrNEh5MG5Tc3dyeXN0cGpkVFV2Q1d5WHduRm8yV2h5c2h3cEVUaHNpT0VqOGNsdXRiZ09CcGgybmJsbjQvSldaT0F6clcvMGFicVVHMUtnNXhySHExWXc0OXEyZ0JrbDZRQzVveGNOMVJQUmxzVStpTU52eDFoRktKMFRNWXZWeWJQU1BReXB2aE1Idm5CZm4vQ1FKRlBkMGdPcDFtTEJkMW9rYmh6VnlrMGttVVBxWDZ3RFB6WnA4OHFsM0sxTUoxL05BM1l6Z2NjdEZuUnpFanB4eGY1SitTZkVIeWNwcnpkUllrcjZRenJHZlVTbitidlg0VVB3MTk1UmNrVzFmVmc1WVJpWExRMWhqU1dtaUtic3VzUjFsTllrVSs3dVUxVlVFMFJoK3FvM1ZTSnlITlAveFY3dWRyZXlObGR3S1FsTi9DSWV4ZHFzdDBqK01TbDQ5QWU0bWxBSFRxZkNObVk0NHZmTGlWdnJWUytwQmtqTVJGN1kyTmtZeG9QdXV2UGhaZ0ZNZndvTFdEOCt2bGJNOXBGekZJZ01wUHEzcDhSOHFNMzBXZGF3bjUvMDZUczFyeWduSm1xbzJQRytoSkh1QndPeVpJQnZMK083ZEp1VWxHMEFBSGhHYUVSdEM5T2pZTWJJRW9wc1AzWVplY2RWSUpONlBsWjJaQjNwVmh6c2d3aGhwSkdYUHZWWUdkVzlFeG1rR1F5UFl5Zk5jOGtHOTF6OHVEZEpyQmp0MDVYWXVZNnp0S0RLNmhvcnhzWGhHWFF3c1JKL1N6RzJocXhsSm5naEhjM1pEb0xKSmFoSlgyT2xQQmVXb1RaWXdmOTVVanNmTHd0eGJiVG9HbHhSSzBJb1dkKzNEb0dSeDF5TVlkQlJJaUIxSmxGODcrNHFIUW5zb3FLYzdOZ0w4UW9oQWJiemcreStmYjkwRHJTRUR3WlZrVDhKdXpHNStTRDROeHhrdmxCQmF4N2RoR1U4dnc1K2Z6c3FjTHNzU0JTK3NHUVBITk9rZVNIOExxZ3FaUGMxeEcxQzhkZHlYTERKTTJlaG41M1pveDUxTlFiSXRiYjJRbUtCNzNGdGdCSlZRbVVtMnNoQytwKzJwOXRvQTh5ZkJtcUQ4YitvZUprYUpyb2pOaW5FTXZ2OEk0VE5WUmxPbmY1VmZqMk1sVnYxQ1dWbjlHYzZYNUZxRWtmdG56dHdEL3NrSVh2T1RwQVZpUzJOZnlvTXRQYVBHOFRMRXFpeHVGby9vNlBTVFlkK0lxV0pTZm8rN0dkVjA5QVlnb3lUTUNnVmlxZjBaUGdiUnk0K3c1NWZsWXdNQTB2Y1h0MkVzYkhSNlZJNlRaWE1Bc29GQ3RoY1NwY1haVzBkV1o3UmRROHFzQmFtWHgrNkg5R3FzM2ZhbWl5UVhoQTV2TDJzQlQ0YmdUQjNQcUV1My9Kc3E3N1gwY1FWbVZhV1NXcTJ2aVRadDhUOUE1SldvTlAzVTZaNFFTSmsybmpLMTltQWkxTHBQaFg5RzhDTWs0STdaMEs1WnFvNlRnR2c3UUdJRjZ4SjVQMXh0N3lQdTN1UUJRK1VOS21HOE1XUFp5d0JyejgwYklwelRHZHpqOXY3MWxCbDhLaWY1REkwZUJjUk1UMDhRaUcrTGVNWEorRTA2OThNeHRVRTJiRVptRmU5NmNvTGJqenlIc0dEMzdoVTFIZVdjOUJDcjFTMUpvZG8zSm9Od1lKcXRScVRIUnBPcjhUcXBvZnNvSkpYQUk3Smp1M2tvbjhYaFlUb0RiaVd4cEgrWWlRSWZKYUgxcUt5U0M0UERJRGtqdUhISVJYK29MMXA5bGoyQ2xvdDZycWJiMUNBZ1c2WjN5b0FOZmhyVUJaN0laYlBiZGs1MUtTU1VXb3NHdDVMS3BvRkhaSEwzMDBqaGJ0Rk83Wmd0Ymp3aTVrQzVQWS9BbS9lejVoUnRCaVp5VnloS0hPMGlnblpIMXlEeTg4cDFVVEl1dDJQVDFXVHRzd0R0aW9aaFNYeXBEL1NzVTBEdmkySW43VVl6Vk1jUXV4UzM3NUNhTjlPSUMrY0QyK3loY0pmSnI3NlQ5aGtmMGR0Q0FaYTJpZmdaU2dxbjg1Vzc4ZVFIZ1p2UVlaS3pSeThqclEreDQrbHIvSUNvU3lEekZOK3NVS2diS25naEFSa0dQOG04dlBiNm91SytoRVhUSjdxOStocU1yWGZqMFM1SW9scWx3RUF2MStDQUlucDdSTHpPT2owdmhHNytrQjVBeGFiMzFBUVEwZzltMzhSTlRRZUF0cTdCMkFPSVk2TUJWVHVFYkg4K29LYlVjU2JsVnpiK0s2a3JEU2l5V2VZZDlBdnZ3SGtlUWc1dGZhalJWajY1MXNER3pTZ2VOOXRhQVdGemp0Y0JBVlRkT0NQM0ZMVzVXMzBUNzZaVkNkanhVdjluYldEL01pMnRueGh6ZnNzNEFqSG55OFE0bENQOVgzTStLZ2tIdXhWaVdERytyUkNNbTRkYWtXMzI5UlNzeXQ4aW5peU9yeUNOTXJWSnFCV2c0Q1duL2dTdkVFb2FZMHZwbjYrKysvcGp0RXI0b2c4eXZ5WEJuOGI4K3BnSloxV0dQT3VEYnp5QzA4WjNYbU9NN3RmUjFJT0pYUDFGZkh2VGJ1K1A0UFVxc0dEbnVyZkJtMGVwdzVLaXNUNldZQVd3MGxvdndMa1ZpNGlndVdTM2tESnFraFFKTjVkeXR3bWE0UVk4L3IrazdXaEtlbWRmOXAya2NNeEhNZDhEbmZDRFNlaUZJWXR3WVpCNlVhNXBsUVMxYzBxc05EZ1BrWmZpM2ZNNnFrS21Qb093dEJScUg0amFIVWl1ZGRSeHJ5eGpGR3prdWY2SmYrYlRUNDQxZ2kxd2JBd240b0VkSkZSamlEN2FhMTRqdk9RdGVPZ0NMdEpMUzdGUWxMdzNxMENLN3RjRExKbk5UMHhqU2pHcTB3UCthMnRRQUxGbjZOZDR4MmU3bFhvSFNvWGhsbHhPYWREQ2ZrR3hXZDhKVkp2QmxVWjZIMVhadlhENmgrYWpxNWtIbnJPQ0hkUGVIT0JPYzdQOGhuUHVHSzZsei9kd3ZMWkhIbDAzTFFrY0RDa0F1NHdKeDMwam9mTm9aSVNMTTVMZkNrSlVpSnF5MnVOZUZ5d01UdHV2V3E0RTZKZ0hyZHY0TzBEdzJMNTJRK0lPeU5wYWJtS05WMytFRjlVaTdLdDk0b1ZjQzRnS21yM3NLRS9CdHI5dFBidFFjL0Q5M0RQNzNuVmVGRk9YR0JCcFVacGRFUHpVZTIyeHI0bnM5cFYyM2NLVm5vTnYraW5Sck9kTVQvYlNWbEpwRW1sYVBZeHZVUnJESmdtc2RLeGw0dG8vUk9pVTRwOGNQKzFEZFhpN0p0LzJIMHVOQ2VGMHc0eVQrc0gzenVXblB4Zm5jcjI5UXFZWk5IM0wvSWJDWk1FU0VlaTVoV3VFSldMN1NJU3hJZXZxNWNrQUs5d2RRQkhUVk1mbkU4bThFZlE5YnhIc0pvOHA5VWtEWWt0K1FiVkRUZDFsbzZQSmxDV0Z1bklSSWxsMTdCRVZYK004cVFZNC93L1FRc1BKTFhidm9WdlJCWFkrb3JGMHcrRkQvL1FLbkR2WnBWM3BkVGdUcUl1c1JjazZWdlNxbGRwWHNvU1RzRFc1SGp6Y2VqV2lMTzJQL1dyWlJBN0hXTTFyZ2dpQVJzZnVuSFA2S3pIZlpESTJ6ZlhJVnluVUU5MzBSZDZIOEJoZEFoRFV3U2ZBcmZOcHZSa093TDRvb05FcFg2TVRoMFNaOTdiWXJ5TmNvMDY5WHlRV0ZoQi85V2ZpVERESzE3Zm9FQWxNU0t1UkxKMlV3aENLcHdNbFBkdEprbHJxdnlESVBZRHJXaEFLUjVZQ2kwamtZbmpONEY3czY5eEhLTXkzaDgyWFZoMWdMd0Z4Tk16dFdScm1tNVlrbEpiUVFwaDZ1d3ZCblpsYW81Tjd6RUNQU09pKzR3em9TRnlQUURuV29YeTJQNEpuZ3hSRmZvSDB5VUNORmN5dUEzYmxXa1lIN3BzNUJYYnJuZldKdTJvazUydkhzdDRDdTBvTUVoNWFTU1RPa3FxRnZ1SWszb0hsMmVKYlRkUHlCamZ5RUhNQUlFUWx6NHRxdjh3VzY5RHp4UjYzckFOaTBiOExLQ3RaZkFrOEpZM2VKMHgwSlFtUm5IM1VUSWVtUCtzbmVWTUZ2b3FXbit0ZHZmSkpUUUtib0RWaFlrcjhMaVg5WSsvQ3VWK1h3RkZCSmlLS2FveHdZUS9taDgvSkJhaWFVZG90TG1pUFJPVnY1aU9ORUp3dWdaV09aeVM4M3Z1QTNpZ2JiejQrZHVITEtwRXpTZTFxZC9YUmVLc3FpYm9iemQxWEZWMEhPOGx0NVVIaUp4bC94WEp0V050dGxreEVGK1NiTXR6RXpNUFlpclhjbjBGWjNXRXFTbzZlMWlrRjA5bk1BSWxGU2VhdC9MWHJoVHl6bUpuNnlBZVpvUDlIYThxbXd0YjRhTE5RYlJXYmFSdjRRbmR4YW5IMHBvR0tWZUNpUVZnbTlpZ2NyT0MzcXBFWlpEMW5rZWNKK0ptSFhSYjh6S1h3d3dBanM3ZlJ4ZmVUWERBRktxa2M0UEZDRUxvek83dWhnMWE3OTJRRkZ3MDJEdE5ONW1JOXlpZ2JmbGUyVW0rRElHMmJsaXJVVGhMM0xDTHdVSUJGN0hRa2VSellDKzBpTEM3SUNMM3lWVm53UWNtVmNIQzRPUzUzSEFxcWNVcHVOdTYrczAxWXVWaHFjTWVlcEY4VElZUGxnMEVEcWRoWk93eElta2o2bVA5LzVISVBZM2tDd0ptTWVhUnBZd2FmSkIrMjBTZURMTTBTa0JRbzhsWWFEL3NBYmtJOHo5cVh3T2JKN0M5RVljQW03eWZQb2w4NUtKeGY2WGh3NDN6WFUyMmNoK29kL2dGMWlWMTBmRkxPVnBTc2xpVzhNb0FJUk1sU2wyU2FnNTE2T3huZ0szemlteGVmMU9iQnNVSmJwL2FYcE1pQ0g0UHpETUp2d3dwbzE5d0g4cE9PdXZYWTlpMnFzQzlQbFppZ242YWo3M0FDU2JWY1hqVy9PNFF4bHlRalh6dDRRQUNCSEJ2NjcybUlLMXcxcWJOcjBjcDJXRHBEUFpvODBaWnFHRWJMc21kdmZQQWVwbWFsQjdnYXJnWk9LVmdYNjlMRHJWaGx4Ymw1QjNxTEpCU0Jnc2VlUFRvcCtOWnNTMmtxMFlsRVJMd0l4WmdpdG9XeGRLL3o0dzI0RTIvY3hmQ0hkeDR5eDJSNjR6YjFPQU03dlBjQzdNMzVVV2RvTlY0SGRZcEtxdUwxUVJ2bWZuOEdjQ1h1VWpNbGszY0dvRk84cmxVYThkRzA1Tk5LMVlaUUNmSlBMdkZMOThHdUdidVh3bUhGTkFQbThBV09WVnVtMUp5OWZRZzVqVEh1V2k0MlBDR050WmFCQjRqRWFjM25HOGtmaGU2TDBnM2R3b0o5QkhTQkRPdmtNYnJOb05RWjRsUWRrcTZKTW45bmxFSmhJbzZoMnMzSVJETVczU2l1bG8xTzJEZXE3WjVnWjN2MWtKOUhRNzJ6Q3Rid0lzU2JqaUZlMytSNURqem4yajFXOWRXemVENTRnY2p1aVFmMU9Zb3ZCc1Y2djE0djJFdlpTSG5xcktaNm5ua2dNb0JRaVVpZXFTOG8renZaa1c0UTlXVnhrYzJKTjlvbzNmWjFSZzZ0cTRpSSsvRDNXK1F2NTNySFpoZ2M2cmhFbGJQTUhzOTh6cHlvNkNzbk9aVHVIMGMvQmYvRTlNL2xwMS9PUXEvcFRtRzNDM1U1K1BRRVlDU1BnR2RvSVg5blNtM3c3V3NLdlYvYW4zL2c1SnFwbUc0SXQ1VWFiTTFPUU0valNUZ29CdS91d0w4VEY2V2E4T3V1Njliem1oR1BVM09iaE94NW45cFl0bjdSaUE4dXdFS01maDF6VFlIOEhEUVRPeWx4QkhCNFdpalR2d1FYTlFOeUdIYjVORGhjcUVUU3lqL2UzQVBmZHloaG5TLzNqSjFBMW0vNCtIUFlhcmNsV3R0aUVreXBmKy84MHZyc2pQNVZPNG4vdlFPdU43L0xoeGloWS9ueFpyQWxaRE8xd2lTMk1LK25yMGFpemFTL2JQbnVZWEhnRURNSzN6bmFaRHdiU3NBcVVxZldmb1VoZ0dqMGVCSmcwY2plbG1uaXVVRkNyTkR2M0g3ZjROcTJoWlVldHhwY0NMNE54WGJxcnptWWVHbjFjYXlTcGJmc0wvOEtiVkJLWDU4dzA2ZTh5MVluZGlnVnBhNUxlTHJCOEh1bjhuTGxFLzE2T3dHWDZsZkg5ZzNvTm1CMENidHBGSGt3WVFsYWdDOTUrSFhzb1hrOFk5bXZPT0NkalJnd3J1N2dZVzBqcS8zbCtyQmNaLzJjemJiQi83T0U0cTh3VHRsZHRuK3A3QXljNXRmaUEydnFKd2pKQzlVNlhXeUp0RVZBRjJzQWd1cWUrM3FLUzJXV1hVck5nS1dETnJYZ1k5bSt2a01VWDlITDB2QUR5cDMzemFhWDZpUkFid3M5dmVkcllzd0FIOUUzYUFFcTdWVmVvWmZUdk5XQWpORTdsR25FMjdDck9LREhkaTlzUHlsSmhBa01qeEdnTyt1YUh2Y1d2aEQrbkdVOEhMN1RRU2k4Yk9VczBwSWx4STArekJlOFVGRTNxQW5xK2RBM2tGNEFDOGdsNEsvOTNrc0dIWDBBL0Z5N20yRlhpeUN0OWRTTW9QS0tjVXNLdnh4VE1WUTU3MjdlZXh3c0lGWkpGaHpmY1RXWnNrSjJNQXhiOThPUVdyeDd4WEdQb0YvaHF6dWNvcVluYyt2Zzc5NDV6dTdvdWJ1REZPdmdmNks0NXZyVHRxTTJMMlVSTDhVbWdwNGF5L3ozSG5hNlF0WERQazBFazhwSXY3eHA2T0hUL0tyQTdiZVNmazRFOWg3YjdOeDFMS0pKaWg4Z0dCbXRqQm5yUlJjODQzWTZ3bTVFcjRJOVltcHNKUXVXN1luU0tvRWhTWU9OYVNyNHg1UXdEMVk2TmhhS2w5VTMwSStaaUVkVzF0QTVhRXlLNDA2Q0tMZjlPTml4OUZZcEw0RVlveE82TEI3N1lJb0hZWUpyOEdFMVJSNHIwR3Q4NWhnUzNXdm9QUzY4UEhObm5EY1FaRjNFb3dSUUd4YS9OUTZNZkRjNzk4a0M5RFZvdXdRSUFWNk9oZXV2SEh1THRYQ3oxS2R5QkN3NGpaOTkzS2tMWi9uMUd3U0lBRGtuMVo4ZCt1enE4cjlORzRCUy9QMzZvWDdiaTQvRk56cUFIdWttRUhhejQ0WFd5SXptNloyNWVZdGU2WlB6aFRtZjFwUVdXK1JRY2tmUStUOHhBZWRuLy84cmhMNkk3RHJaSTNMam0rTFIyTTdRYXhPNWhSaEdCMlUxMlZ1QUswTjRDdUdLTFdFSVlQUFlpY2RaOHJjelV4Vm9UZm5wL2E1RHB1Lyt4Q2FDMzNjaGVCVDk3RVk3S0pnS0tkWHBXS3RNQyttNVp2Q2JTbm5xNy9rWWwwNHV1Y3F6VkNzUXVGTkc0bWp4cDJaM1VzVjRKa0FDVktKWkVSTmJlUzc4dDhzV3hjRURlS2ZFQkhEYXFpbXRWd3RHWU5URGsxSi9ET0FRT2FkNTBTd3pyRmhVczJ5VXBwUDJROTdLZlk2VzNiQjExQjBXQlVOV2RyNXN2TmMxUnRRcHh3czV4SUwxam1meW03V0dWa3hTU3paZEZoUUpZVGtBdkJLRDdFOGcvWUpnb2VLTmhpWjVWRGFmQ0dHMVdrUndEYklpVk14SXlTNlR2aHZYNjUvdFUzcmFOQjdqMVVaOE1HMVlteGlvdXV6MVVhelR5cW1iM2hCSU9WNkdzYnBGSjhXSnV0ODdmaStacWl4TlQ0YldjaTZtT0txRGljdVJxTjVtRFVpS3h0TVYxenp0eE9CajloRU9aQ1pSS2dtZ2twdTVmdHg2QWtta0pRTFdPM3pZWG93QWZINjVjeVF3MHVuZUtZS1JWZlhoOTlSR1JyeXA0S1dWR2VMMTdvNDdvSDhncDFzMFNrcUVqRnJDSFpPS2xCbjBLUUdWM0NEWVFhR3dMVkh2NzhKSHVTU1BualVLVFpqYnJFUjNsTi92eU9zYjFOYmtVSkZkSFVvY21MeGpTcDFuTXRZU2o3SFM4SlZDK2taR2lVZm1hOWpEL1NDK0Y4aGF4SU9qSkNKak5iZ2o1bEcvY2JCNjU3S2V5NEE5dy9GWUM2Y0YyVkJjdWNFUk10UVpiMEZtd2Y2WGdkSDRxMlJud3RnSXZjeVNaRzZKNVJXb2ZQd0dpeFhxMmJKNzFHL3MraHZGQUVybUhOd3RCdzd3RTdBMjRmYW1vQlE0dTdhUzFKWjVkTU5BZmxYV3dVaEZmRElXWU1sQWtseVRZa3o3Y1dQWkNEOHNqNWQ3TTJwNDhBMDB1TWYxd082VXQ4aWJ0ZUdOakxRUmZ2VXVCZGN6N2lMR2xyUVdNK214YXFtSEV6eWcra2l5MzVSSDZXN0ZVNE1OTEN5aFUra0MyWHFCMXFNMkkwSXlKZTE4S0w4Q1BrVE1lYUN1aldXcVIwdXBHZk9IOXZoVkhjNGp4UndYSEpza2E0emFHekx6aHA5SmErc3c4Mzdwd25vbzNHUkZaa0FMazlEN2drRU96QjU5Y0RMQmZRU2lGeXp2TE9IUHdOaCtpWWs0Y1R1K0ZLWkxaNm1pejNnSWFUMFM2Zm8rcWVxNG0xVmpHSENyMnRheVVCb28vQXR4RGVxMU9iM0cxRng5NGIwQ0lJeGJobEdLTFEvc0YwcWV1eDJnL0lHS3lyK0p5SlVkNzZBNFZOVmloTlkvRUJoZnVMZnVDQjRRQ0dkY1FteE9Eek9HYUJVbkY3SnR0UytGRUY5eG40aVFtazNlUXlHTVVRUHd0ZG5ESk1oT0hzamJoNnprQzdoNEdZTVp2VHBzZGtGY3lCOGRKTXh0enMxR2NYaCsrVVBudjRkaUhvUmFUVjFUdUZlb0t4WWxUcEQyaUY3QTNPK3E3SU5RY25TSUZUb2N2UXBVV0dyQlAydm8zVVcza0tJTXFoK1BCd2xIU3krbEtuYXdLNzVRMVkwNXFwcURqR3Y3c3NISHJBVHBsVTV1UUZSZG0wMytCMXNUNC9LdzVKYjZXQ0xjdEo2bWthNTY5c1lYaTlISkIxTE1EaDVLS3B2NWlCTk41TnI5cUM1b09oU2VodGE3Zy9wWUwrVWZOaUVoaXN3RXEyRVcrRVg0N2FXQkNIbWRwLzhlUlVsM3ZtbGgrZ2hxVWRZTkhNZzJRY0pSWllrS0NMR3dQSGplUEY2VXZDejdYUkxJUmg5TjFoeDg4QXczZm1OQ0JuQnZhbXJrbjlwYi9QR1B1cTZUVVY2RCtnMjRib3hZOHhteW5nb0xKYStISlhnb0NvZTdYTUtXK0VIcmVFeE42bzNUK2tySkpLZGM4TGVnNS81ci90NGxGeXgyZ2Vmbm9jTnhtUWM3SkZYTFcvY0R4bDh2M3dWZ09HUFRhSHBEZGpsVXB4L2xPSWU1UzFEeDVqdnM1REdSWXlmYlVUaEZHWmx5Ulg1YmhPbjdKVkRFa1FTTTBJdVpOY1lPVU1lSWJLS2ZzVXJpblQ2S2lETG9tU0xjeFZxbC9veVBMd09WRmdjNEZwbXgreTY3MTFQSzdGRXkyVnZseVNlaWVSRXNEV3V0RmNrUkU4eFhIa1I3QXcxTWJEWEdwRUNGcDE4NzYybS9iV1JCV3FMcmR0YmtBK0FzRHFIdU1DbnhYMk5taUFhMVNTOFMzTk9RSlJTempTaVdhS2pITGRBR1pUMTBXM29JdWlSQ09wdkgzc3ppQ05KR0pLOUtSZCtlblhSeUNCS2FVenVpSUV5bzc3SmdCT2tGb3c1QUo5NWpNVSsyQWZLVzZCSS9ndEhKYk0xWVpSWVdxbFVxTTJtd1liYVAzcVNab3JXa05VSnkvN1RrZ3NyMDVNSUYyV3ZHNGROMFhyZEVkZS9tOGNEVCtHclN0MzVkN3JGYkdzUGpGbTNWKzQrL1lmY0QvNmtOWS9xT3YxUzYrbm1tcXB1ZEhWVEJhYnZoZks2OUpidldSMEdqYTNaM2dqdXlWWEx6NytFR3IvOFN4aHpwV0p2aUlrNERISjhqN2JBZ04zR1VzY0lvZWtvam96blRhS3VYNW5tTUJ4dTJTQjR3WlJhY0hJdnpDZlJCQ0pxdG5EcjgwSXorbXdsV2dCK2t2WGxzd1B0VnhsTUVaWEgxczVjcFdFY2tIdkZxQmFmMDFUZVVic3duRkVFUTBFbEsvMjV0YUZKSGlDU1pXc3J3MFpHTm5rbG9mMXVwTGZmdExKYjhjNzJET2d6NEE0eGtZL1kzMmVUV2xWQ25xMFBaT1N5ajhhOThuT2hUdTJySWRYTURKcGR5QUozazE2Q3dzNnFDVXExVitOOXZORjBEbS91ejRCRVV0VHdhWU5OSGNzMkxOMFZCZW05N09iMzZpdlkxWTNqZHhXdFRtUVZHcTU3NXNzMDUxN245d1Vsaklkd1JxS245MWdsNHpnbTRTRWZEVXEraW9WWkJKbm1YbzdTVlZHQUREa3BlWkRGaWlaTkNsRndFQjBoYTRkcUxFRzZRQnpwaXI1U2J1cmhpbk1WN1R0dC8wSVFqbDVWMUExaW1zS1ZVejRXb3E3Unc4S1RPMlFLR1B4NW9sb1pDcmxHRlJhWVdaL1JlOVlaNEFFcWUwcURnZDVKbEI5QnFsTVhEOEREdENMS3JNS2g0RE5MZEZQV1BaYVRSMjh5b05kUzZrSVV2K1YwNWRJc0M2WUZra1MrTTJnckR4YTZ3Z1o4TjlXYXV3cVMrckZIU3FpRUJDbWlpSzJmam5wejFPSzFxaVNJb3F5Z2RHUzFmejJVd0Z4OXdhK2VkZTgvWWVIcy9kOS8xQzR4RWJxVXlOc0NkczhyMWpXL3AzclZ6WE5JTUVtNFN2SGU0ZG5yWTBvZWRGcEJPR1JYeER1VXRabHBDUkdKZnRJanBBMVAyZVM1UStSQWdDU1dmNXpzRmtHeFJmS3NER3VrWXM4Mi9lY3RzWHdLNCs1NytXVndJLzJJRXJjdTgvK2crQUZFU2h0WElBUFNNcHdIWXlxL1oxZmtMOStUdlAySzZwc3ZMWjBPVlp0SGpoZjlMK0hOd1F6UUFrY3VSMkYxTGFuaE1JdXFnamEyOGptc1BVV3AyejBJQUFZV2x4OFBjMHg5NWdkNGxzaW9LYXhiSXdtZTFpbmhDMCtXZGMvZVZsOHNKdWZOalA2VmFON1YwOE1mNUFPMU1remRVYWFsdnBrQmRtYStGemN5TjBUeUhZOWlCcmgwR1ZOMDI4eDJnVWxMQXlSTFNaUXJ6MXVTZVc3V1FUanE0RFd6T21FWGhJdEJhSGF1WFpJSTRpYmlPYmVYMGZyMXdUNmk0NGxLdHF3ODNSekh1b3FhdmswUVkvUlE1NVdaSzhEU01xNkVYZU5WZDdJOG1aWmgwbjBDckFuWG9qdVZSak52aHBwTzB3VGJHeXVNcjFHUTFMRGErTEplQXBCU2hXRFIyMDlTK09GbkR0cFl4TU94Zzg1elBwaThPVVNrSGhiSCswSjRGUEV1c1luQmI3WWFHNEVLK1VJOGFhaS9ZeDZrSDc4M1hybXc1bk96YWQ4TUxOMm1HY3dUQmNKNXNrNFdrUWsxNEFZZnlxNWRRM1FidmdxY3FieXVuUXlvb2hIaFNQUDRXR0Y3SUJzKysrNVZHYk9mM3JEVlcxKytuVjhvWjBBRnU5TkliMXhiYW5tZ2VpTkMwYTRERUlEb2VXK0dGZVVQTGVROVMyYnBCL3h4b1ZSWjZDMjRkMEtCZ3l3d0ZleWNudE9pWWdoTmtNU0xpang3TUVwMlVvOXRuS3c5ai9WZnJXa1ZOcWRpanBJcTFxcHc0YXhpMHZrcCtqQnJwcDZtajNQK1MySGdpazJtVWVVcTFoSVROTGZOYVlWRXdaTklQQ05BdEI1NHoyNk1jYllocndVNTRBL2lDWk92dGk0T1VVRjdrMzJDY2ZKVS8yeitzL3JtdGxoNUhDa05yWVk5dTZJSGlwS3dOMVNUeDZqVTE2czdlMEd0R0ZFNGxvM1hWQUkxL1RwMkoxSXEzS0Vyb2t1R2NUcGQ4RmRoWjgvSFdNc2ZTOFh0dkE3WmFpd0pqY1A4RTdjRFNXdklROVNiZnZxeUZrandzRi9FMEY3Y0xYNW5lREN6MlNWUkUyeDlLcmx5RDJTTC9pUUZyNHNDYktrK3VSbER4emw0N3lIcmczTFhDVzU1Q1hUdGM1a1RUVkVnUTN5R0xKdHRqSVZzZDlBRjBERmR1Z2VhRnloTmZYZ1pZRSs1K2lKcldQY1hUOXhWWVhMR0ZvNkhjaGxaeWZud01RMU9FYmFWYnkwdCtmTjFSTmZBY0UxbWRjMkF3QzZsSlNHZCsvMVZQdnJnV1YzQncxOGRuV0MvcUVHZG9mSjlxNVJ1eXJEeXIvYWVPUWV2R2l1ck9yL3N3N2w1ZlJRNEFwNWZJQnZkVGVySlpyd1BhYkJHUjlqaWF5bDNZMkpwRnFtdktxSDFzQUV5cUpuZVloei82SVB0cFhERmVha0N0RmJodFNneVJtaU9lU2YyRGZ4RzZrN1Y5aWlRdXJkVTFaSVNNRk1zZERUYWRmRTFmeXM5Q0dLRFUrZlNsQ2ZPWXZvRVkvY1pENG9sV2pUT2ZaL1BZd0VDUnplMTNDdWN2TGZ2VDJINERpSkZwYWpOcCtub0g0c3JITzNZdWZzN0dOV3pjUllyUFRGVnJqU2xlZXFjRTVWdVdaZEVnY1IxbnNjMlRsZDRNOEMyQ3o1RDhJK3Z6WUJRNnFqOXFvZ29FSUVqMGR1b2daWjJraVVyZllFUW1ndmExc1pacGJaVkhSZnZCeXJCZTl4SjFwTGVJWU92TGhSdWZEQXpmbVRRZEwxdjFCZG01VzZQdCtjYmF3bXhnRWFyaHdCcDVzZmV6c0VITno3bGNsanlhNjBURWxxRXE4UUFpOGdrM1VYQisxaWpMVkM3Ukp2MFhKTzlmWHRwTHhDeWtkaHJmbmdnbHFnOGlKVVJNV1pweGxKUWFXeCs1ekdncTNQUFduUFkyU3NLSVRZUFRKQno0blZJSGdBNnZqZmUzUzhYWVFaTHMvazBOWUxlekEyeDcyQWFGbEdHL3VQZGx0cnJ4NW9pVTlnTEZMV2lQbzliblRjbmg5M0JvY01kNG01VDArODIxMjhKMVRjaElSRDhESzUyenVkSUxLczZSK0pJaTVsSzF2MWZEUDZPck9vZlB0dmp2ZDZlSU44enJENzkrcDExbkwwVkJUb2ZGUzJndmRyK2R5NzE2REhrR3ZtbHJWTGZFK0dFMTZ6dkRwTHVqUFZEV3pUQ1d3WWZDbGdmeS9kelJrbGdXTUtyUTRRZWJmb2FiTXNuS3NYMjhiREVXaTdGTHJEQll0ZERKaWNBdmwxSVhDTW1ZNnFPR2lMWi9MblFuT2h2UDF3VldjOXlVWWFFdmdRekhCQ05zc0p6UmpIZlgzTXBCcExZSVRmTmZ5Zkt0QitsWDJzMDlxV2lZVGZCbzJ1OWdiaDV4bnI5S2lCRW03cVZrMXh0bmJVcitoUCs5RktMRE5Wbkt6bUxIcUlleXE2VmQ1dmZFdTRkeDFBcVlmQ0Q1UFJJRHVqQ05Zd0J5ZW81ZnhVRWgrYWJld0NmbWw0dmtrYVJvTTdLVEJzSFVPZkJubTA2Mmt4VStMYVU5Rnc2OUJiK04rMVFydGxQZGF5OElZaWZvZkhRcTMvRnNRbXRCcDJNcXdQL3Vta1ROUVIzWUhaaXNvUGljdGtFQ3N2NjROTVYyMHduZTdVajZ0QVJaMGtpN04zRnJ1dkRuS0JsYVR5QWYrMmt5dmVId1k1UFdyWFp0emVnSE1XVlozeStZK29pdFJZK25PaHZDcDRuVGFQSzIrSkxra2gvQnVDOHkzWW4vcWViZDBVWE1aZEd6N0NGSUFlYUxHaU9ORDVINkFxTVJjcGVwTGtBNEhCT1dzeHZTekR3TjI3VDRhWEFLdVlXV01ObTJ6TzFCNEpySld0R2N5MW4rRHJlbUcvTytaNHFib2ZibmpxTTJUdTNsSkFuK0FQZ1JINFVpQVkweVA4T0VtMDAwck9mc1VwQlQyTkNuL3JKdmFPNE5VaWl5SEljMXJzWWdaTHA2QW9DZGRPd0UvVk1xQjNuOTZXTFpQZTQ4ODdwdzQ1cWFuY0pCZHo1V0NpQm9mbTRVdkdBMU5tVUNrTzF6emFkdVFVWnpNRjcvVGNaaU9CUTFuMGp1ZUdrL2JWSjRhb1lvQ3VPQjBZb1dqdDBhMFJaalRlSEp0ZDA0L2JaTmdjTzFidHpxRUNrT0FDQkF6VnVJUzVBeFJ1NjBOL3I2a2NoR3dQTTU4anlKUllXTVJxbWMwcDBxNlNvNURnY0VDZnJQd1hUY3NjMkNnem10cjdMb0gwdG5GT1ZUN2k0bXJHclNNUUgxM0xhNjBVM0RaOWVYL01vS2hiRXY3bHUrUS9iakpaei8xbXZSWE5tU0E0QVh6VEZPbHIvMVdzcFpqMWVOcDVLb1ZyLzZ5MXhScXVBcmE3QXNXa3c3QXBadmMycmUxbm1GcHduaGpGU1Z2MEh3UERMeWtqa0NUaTc2cGxZU2JrckpHdlgxb0ZxcmUyOWtyL2NwTk9FZ3JKWERyckRwS3Y2d1JVWTh3Z0NuTXQxZUxZT0Y0MlQ1NjI2ZEhjNHppZTlQRjg3YTJ3RUpyNEdUdGhkVzJKSFI4QzQ3bFFjV2ZlNXE5SDFiL21JTUw4aGgvYldWWGFJN2xMQjFrdGFMRHR0MU1kU2djeHpZb3ozcjFTdzFTL2JVUFJRQ0VlUFI3ZzVTUXAzbThxTzlxa2tScTFtbHJmbDRsZjlIdUlKcWdyTTFrZFJoVFFTREJZSTZLYStzVnQ1T0R1WVNqSXdXenB0Y0ZHK0Z4RFRnVlVTODFkY25ValpEZGR3M1J6ejJGTC9PRytDZ2o0a3FKNndYY0JLNVFtQVlTdjNJb0NUTElaeVE3SkRzYVhEaXoraTBSaGZjOEhFTnBjMjNvSlZEMHBTSldFWlB6RW44MzZRaE5NbzF5cHBkNmpMTHZlZmd2MVRXdlRYazhzTjlHTzd6eFVxbXlObVJURFphMHo0VkI5bFlBMERyL3RucEpNV25uZTVhME5PZVEwRkR4RGc1UlNYRFJRZ1RlWGg0TU5rVWFoZitrWW5XaTFOaGxybzdkd0EyTGtLM2NVSTZzYytYUVFOcnBIOVhKMTZHbkN0WU5vRURCMFRkT0NyS1pYQnlrY3NTU0dQNmplcFU3czFFbHBaaENjd1l0NmtZQmRjMFhwRVhvMDlmWU83MC9CNHVsQ3FwbUM0MUhZOGFVZ3lPZ1JGWjJ3TUhRMENCTVJobG1QU2dRRzNLa3ZhVksweEdITXpJd2RaYjY1ZGE2UzBKQm1Rcm1aQ2tjY21STUM2akRRdFVoTWVBZkdmZEtNNmRrQmJHK3MxdHp6ak5FSlNRWEI5NmNLYTcyYnRKNDh0NUN3T1FBMXlFd0pLMHZTaUlaT1oyTG50SkdRN1JqU3VBbWlGWTZQOXdHTUxNRXpuQkdIVytQWXk2M1hlQXAwbElCMUo4alppQm42Y3ZtOE5Obk5jRnMrVXEwZjNCU1JXUTFxem5Cak5KTk4rekZ5TmF4aFQ0RXVlb3N2QWhsMWRNR29RK1FyeXpZeHZXd1dwSFZrVW45eXo3dWpiUFgreUh6UHpab0wvMzVNQkVqdEVsWE5jLzk4TlFkNDlrRm91a2taOGh0eW5jdHVINTh6MnRoM0dEWm1DeDk3NURIaE9XOCtoSzYyb2ltdGpDK3RVSFhyZXljL0s0aUdhMUtWWEtLSk1UMEVFUVBONzdBTlM0ZDkrdU9ieVBuekhPeERlSEtVL2NUNkMrOTVhMlluTGlSR2JIdzY1SnVUZ2ovRDBKcGtVN1BxcmtsbUtQS1A4T1dwejhPOEJaV1ZTaWdkdll5NzdHMWRBd2Z2b2dtaGt6cmY0MDBzVmFYNzNPZXdFWitVdUlmNGtqdDNNa0IrYVZmcUFXd2J6eFNUVUVoRlR5Znc2Rmk5TlR5U3ZjYTlxUzlOZ0pUUFVBc3RqWVBHb04wUXFTOE80SU1IWmFhYWFDTVY1aFRjcDBCTVhNYkNKWmVLc1BPVk15aEE1bE9hQk44TllKbWNUUDkvelRIMkdTSDg1bGZEU3c3dHNSTnBqZGp5SFVSdTJiVlZ2WlZPZjh5S2hsVnc1NG9XalJtVnJxNnp1T2dqT0ViYkUvZGxJNVIxM29sM29uRU1yWC9GSlZIZWJCVE9DaVo0TDRPRXFSOVkwdGpiL0RDS3RiMDB1bGF4WUJEeFBlWWhKK1BnSjdid2g5TWdYdGlFNjA4TGVOcGtJcUYvaU13WE53K005bXgrYktiR0pmREx2WGRyZ1Jyb1NCcUFyeUxPd2M5NVlVQ1ZTVHJSbUZRM3V3alBPRWJHU3JlbmwrTllMeUdKYTZVRENHTHhRTS82SFdmSTQ1SXRUcmhTZmlQMG9NVnovVC9ISWxvTnljMUE5Q3g3a3gwY3ZVRjZndjlhOGkzWSs5aE13MVhCV0tEK1dsUzN3dzJxdnVKL1V0cHJha1FaY0xIOGxVOTQ5RWJXRzJqSXpJZ1h5WkpFM1BiTDJ1RGRndjhCTDkzcmtiMitWc0tKbFVWZ1B6WE13WlBOQ1JYMC9ISy9FWnM3MEJvN28wL0szR2pST0RBZlpwN1dtUlNXUmIrUEl4dmp0MDdRSE95UnloMWNhVVk5N24wMUx5SFd3WHJtY0w3eGZNbDk4SnR4YVVMSld1TmVqTlo1Vjk4WEF4QnNocy9WNWJGMHQySWE5SjhibUg2U3M5R3ZlZDBJMCsxTHJSUnpFem11K2s4a1V0Y0FQUUdkRzk5SlJzMVNWZldIekg1WTc0cmpESUxKNmVkcUl5UnFpSjBDdkd4R3lZL0lWeDhKY1Bpai9LOElRazVzcW9LZGZ2ZU1KeXprbVBsUGtMWFlvN2xtSGVscTJUeTlLcU9rSzFKNXBCTGlFeVlKZm5oanlsS0svaURRSytOcVd4c1BRM0o1Uk1vbzQ1c0JhbTZCNDRPcXpPRDROMFJOVWk1NmJ3Mlg5VmNMWDdDbnNVZmVNa1U4Q0Q5eDNwQmZHVVFtRmZhQ3ZkZDI4cC9PWE5DMXd5OWtQMmhWVXFOSUtQNmxjMVRiU3BINjEyWXBQZ0thaHE2OFNmRDhKbUo1d0d4bGtkSWVJZS9MVTIyTGhlR0dkNlNRVXRxdjVlVkZHaEpNQVE2eUFzZmFPOXRsUHpyUFF3aktLamZPbHhPL3FkNjR4d2prdXRjQkQ4bDE0QldnejlyWW1BemlFeUlHQXhxSWFjTWZaZ3AzSFFvSGJRQXRmTitId3F5ZWg0UFlXeGpDZEhDZDlubEVITWtuYnZwUDF3Q3RiWUl2aWRBY01JVGZwTmNuNUxvOHduSGtwS3VvR0pEdUVGM2JTeUo1R1ZWNTFrcHg0bFE4T05aS29qN2JvTXU4dHdGOUdjVlhpWjRyRnR6M1BBMDFaQkwrbzhxZHd4VEYxSkc5RlpQZ01xRWxPc0w5VXJiLzhjSVYrN0FCVlRnVVh5WFFPem9tdXczVkFCVW5CajdmcVJLUUFXdDgvOVFPeFNtdkpxWVFBbEY4aWhTSlVLMkNuVDJPQXpxOWJLd3l4Y1ZKOXhsYXFvU3pWeW50MTBhaEs1bEF0UU9tOC8zeTZuZHlRY2FZUkJSK09tSS9MbkYyNUE3WmhLbURKZ2pnbjNyc1RTaklWbHlEQVNEZVZ6WnFpdzFOb2xPWDZzYU53Q0hxWERwVjkzUkwyaWUrSWg5T1JsR04xbTREdStDVElhYzNMRzIrOUJwdzZFcTU0T2FyK09NU0x6T3htVDFWT05WbS95NWtKSjJBR2dTYWVxSmYrQzR5T2hoOHdqZTVwL2pXK0Z1RGdtdzFjZTlwLzAveGxUaHlzc0ZaOUZVVUNSOHBwRnNKOXcrYlhsYUQ1cUNCUk5mSE50alMzVXAyWlZiRVN2UjlpZ0lOVDJRWTExU1NKOGhzVDBycllRMnJURDhOV2FDUUF6ZDBYNi9jT296a1NXaEFaVFRpckZDRnFidDRzVmszMnliVHBPUWtKZDFqZzBzTEhLMk1OSk5HM0dpN29QeEVLWlU1VzY1NFk5bGVDMEgvRkxtQTZFZ1ZITkF2TWU0WFByTVhGaXFiSmtqMUhHV2ZYTUY2Zk90bTdaRjRlYllpRGtvd2ZNbUZueHpSZktjN0plSDJrK1c3SllwMTZKTk94NVkyUjhRRzVSM2dueWI5T1J1Y2h4M1lrbkE5bVVWZ0g0cXFmU0NxNU9VVFNxcXlWNmJXSzNvZmNscU9VUHowNEc3aHF6RXhiNUJVcmJhTWd5emRnVmIvNlFXK1ZnN3RtMFhHcEVZcm9OT1ZmS0xhOC9jOVpsc0hkWTBNRDJDa3B5MEQ2WDBST0FWeDFVaWtCZkNRUHFScW81U203QVNUUmdVR0dPVWFwZ1BoWGFtc0RodllEYk5OOUtiUFNDYllsNldHVnh5bk9aaW1VSzRNTjdkMVNXdTdjVW95aTVZSmVDNDd6cTZkdTBkSzYybGphTFJlUzN5TmJTeTlSZzc5NzVYRnVONnNickVDQVdoWEFJTm8zMmtKeFdBNXRyc29Ia0hYS3RiWXhoclJjeXhQcnB3ZkZQNXVTZ1F4UC9qT2tjTVY4MkdJZld1bEliRElHWU9RalhsZkcrTTNUWE9QQmY0L1RWZER5Wk5ueVR0K1RjS25lZGlMaWZwZkcrOGlZTlhsd3NYQ2tocEhUS09hOExxVzVGRGFXclJ2ZUs4cTNxZlIrelNQeTZzWUxwWGdaTnJxUEpDa0tGUXdlUG8zdVpRUDZ1MGEwbGZ2M1I0Tmg2VC9udzFWZlhWY1hnZDQ2S1Rma21FKzFnaDJ3enFJcUhFY3pIY2k3ZVdYV1pSTFFpYmJseXM0VVNxMy9xNHlocVpUVHprcVpObDJPK0M5d0ZkbjFCbzBYWWZjZFBMRHBGcm5LZDZ3OVpvV2ROZjVubWpRQUhhczU2SjkxRWdHR01weFRxTXpjdGpKZUxkb3M4c0dzeFNuRklNRkZOZE5lbUlOQlNGck5RVUlCRk5xeFA2d1gzQmpsOFZkUHZTdm1tSnhWVW5SMlpFS1lqVGJYQWlob1RsQ05YK0NpUHhYZWlIaFNOeG1ha3hzbXU5SW9lWkowY1lTUzlLY0lXMzRlNnRSWWVhb1F6WE50enhSbjRkSW96bjErL2JwTEpBa3V5bk9VVUV6a2VnaWlncjhjUzRtTnB3YTZDQmxnM01YSzhOOW1FSCtueG81N3Z1djFKRzdjWjN5TzBFTWNxZ1dxQjRpNjNnSVNybkplM2dGeWRlckdUNzBuMk5wcHdZaVpkanNpeFlBTkowMk5TWTFpUi9lL2ZhdnZUU2xTNXJTdEdYMzlWUmpGZm5hS3U1cHlKcXBpMXQyQ2FPVTRGcW1PWlFQUEhNVTR5TmxjTUFqSEY4UDZqZlI3Rk53bFRyNTZrUm00eS92d1h6MzRGMFplZllXYlh5ay9iVS95eGx6eUxuVE1hM3RYR3ZPcGswc2F1aGUyYnZ2OStveGhPYUw1ZlhLc1RJRTZCNXFHeGhBRXVuZ2QrUGtCYnVPZGxoVGpJNllvMmd6RXlVazFKTU5SZzVKbjJUenVwNElpVHZoZHhVZjZYdnMrTnFrL2JTaFBiSElTYnIzR2NRdmg1Q1k3U0xtZ3ZlcklvcEFQOVhMTzQyVGRRVGs3TTM5amlkb1EvU1RxT2NNVUJjNWt3ek5KZHpiNXFOMi9UdGNEL2hVOXBJWUtaMUszcGd1bTFkZUIyRUJUMGFqNy8rejQ3SlB6VWVteFZRenVic0RRd1BUb1FUdEFxaE9sSTd0b1B0TG1rYjNYYUx3YTVscklRYUFHWnpDeE8rQ1lpMzh2eDBLWExONTRHeTR2ZnNBNHpVaEJ0bmtKRGRlbkZnWUQ0OU4wVFV2ZE5YUHBXYUVyMHd3SGVUR205cWpxK1EzOXc1V0FRKzZSZ2hVTFU3YkJlR0ZBMGhsei9lRnpCcWkrTVBvRDdTUmUyUmFoQjVWY2YzalZiUVZvQlBqWkh0MG92WVN2Q0tCREdiSW5rWllkamNCT0ZxNTlBTkFsM3J1NFMrWWUwdjFnWG9ORHpvQ3M2WWd5QjUvWWx0bk1xWU1UNHRXV2s0VjllNGVvR0NGU3lPTG5peXpxeVBjeHdRT1NEVEpqTVJZSXFyYWFxeVR1RG0yanRhWUN0MGR4M090bFNxQWhnSmM5bWo0YytSTjFraWJ2azVJUFRpNnFUVTNmYWxpVmZLTnIvVVBsR2NIMTdpdnMwU2tMT1E0dHRkOW0vcG02QXBQRlB4YWZoTDBMVUVnRjNjdG9HcnNzQVM4cVMyTjhrWExHblVUdVhmZEcvWEhTdmMyVmh5cU5XcFVycGV0ZWR2dllwUGZHYTlsTmRwcHhrQW5aTjZWVW5XRmZtQjJiV3BQbXpsOWtjSFZDQWVhU2NPVDRkMkVnY1VNSlV1R1hQKytjTWUvTHhPWitoMkx6OVJPWHFURFExUmVnUUdyTXhQQ0x0SmhYOTJtNGxEVzMwbW1SYkpnSlNwRHZKUUJLMEpxSGtLOEVyeDRGRzBaRllYaU4xK1FWMG9lZWJiaWF5T2x4WEF1bno2akpBeW42NlZreENweDVCTzJOT1ppazM1NzhnanVQQllJeXVzenpLcTV0Z2VUbEFzKzFWNzR4ekZDK0k5aGxMREtqZVpPTG9RZmIwdG1VUHlQalN3UStvSWtiaUk3N3haK3hPbDlWejRRMUp1UEU1eDgxRDZvZTljV1Z5U2U5bEsxVTB1bjZTUEtydm5zSG95dWpzc3VPbS9Zem5zTVRlU2dIWVlPM3J1KzRTWTVNVCtzL0dETEJYL3ZOWHBVVTN5VnJMRVNxb2s2RHNYTUE4anRYRThLRFZRelJvUGJNNUw3YUdVS1pYSGJ2RGVnVzZvOUhpL29vVmkzRWxMQ0pZREFZT2RzWUphanc3YUd3dXhSQlkzNitzSU1jRkwwNVZUSWRrV1JrM04ySGVnU0k4MGszTUpRNkFZMlNVRTUxV0xzbmlrdWxqY0c1dVN3WVRWRlNnZGpCN2xML053bkhZNzZkeXB3OWRrRHFvNHdxUmhucjVkZmtvOVJ4b0FDQmNMU3UvNkVHZk1PZmJVUzNzbHA3ZWlTSnBIclRsM0VjZ3RqYUNVU0FTUGJONlljTVY2a3ZnNEdLUWVzaE1nK1FrN0g4bjdSVFVVTUxhV2tYSVFpOUFWY0pxVU16eHVvR0tkTTZuc1FTZXE3U0RpVFRVRXM0YUJTakhiYStHcEtNZncxU1RrbTRWdXYzS0dXYUtBVHZteXByeXNEREZOdEZWY1hlRnl3dklocWJYckxpUXc2bTJzMjVMSWZvcWVaaEhDclprcmtuMlllSWphM0xmeEFEOHh6N0dpTURxNDFtVm93SHlEMjRYTGR3SE5US3dNZytBMjA1SXV6QnlZS3Zpb2VScTk1VlZBc1MzbnF0RnljVkg4cVgxQk9HSUtMNGxsUUo0R01xS2NjSVAzdEhNVEQxQnduNk5IZFhGUkdhcU1tcXRXT3ZuUUlzOHk1RWdCSWtYQXRJc2FBRmRKNkhmeGFFR25td0RXd0xyMFMzc1JpSzJwR1FZYjBkMkREV1dGMzZVb3NIVm1iRG9iV3NpVmdKbnREMFgvTHJYWXlLdmpieVEwY1F6OWNnOVBHR2gveXpFd3RjN0NvbkFIVG9IaHJ3R1gySXQwbXRTMFlpR21jRHVMRUNQNjNBR1BuQmlCMzZZSEdQLzFreUI4cHd1RWJHTms1UjA2S3N2dmRQQ29zVkMxRjRraGdFSmRyVm5LU0krb1NvbmFHQzdSZTc0aTRLbDA1clB4MjMydXRYWi9KL1pJdWFMSmkrYmhHblMzczR0dlY4T3Jlcld1ZU5yZmdrWFVyS0xraGMwSWFlS3duQnYyU01ad3UyZWZIZzNIS3FwT2JRcXZlK1NucXE3RUl5T2pDUzlxK3pkMmhmUExOM3FSODBXLzRFZ1pLUU8vMlRzeVEvTGQrOC9zVzQ5cmJ6ejdZZzV3Qit4MnJjY2ZvUlc1U1R6TzNUMEoxTjZoTVVkZ3ViVkJiMFQrU0d4TVQyY25tc2wxN0tZNjFhVHJjYllKNGRiWENTQUF0dHpQcVlTTFp1dzR5U0JSUmhvVGYvQmh4S3FaSGpUNHNXRnJVTjFsM0JpYjBEQVpJUFpKbG1pOG5nNURMbW9uK3J3NFY1MUFMMnVQNEpzL3Z3eElKN1BFb2l4UWdrV2c3VzljdmdTWUhXSDFVbGoySEJIV3FibWQvQU9kNkFYYUhJcmwrM20vZ2pJdDlXUmJrTCtJRkVMY0E3aDJXNXNyUUt1OGRnNENhMWl3MFZ1ZURUV0QxNmlUQlJhdDVOQmlUdCttU0JyN1NtT0tzeDYwbXJaNU8xcGYrdEtYUVFpbGdna1pGcks1VTBLRjk5VW81dTY0WVVPR2lHaFQremI2aE04dHpacXEwODBFNkhYb3R2TTY0emR1YzhwWm5zcHdNM2EreURmaWlYV3IrN09haFV2MEtVQSsydG5yWUJna0E2Ukl1VkxkWW9EQVVPNDB5RjVzUDdYb3JKeXk1aTZETmI3Y2M5SVNjQ3F1RGR0VVJ5aW85OC94SEY1VnQ4M29HelZaNkdEUGdYcWdhQ2E2UWpGUTM3dmVXQm9PdmMxUy90YU1tODRuRVdRQ3YxbEduV2tkN2xsNWMxQ0hlazBaZVpCUSthbUFIenR0RzdYMDd3cnF4dDRncXFGaWY5MjYyK2tqNTZLbGpFbm9PNlNSY1A2eUFJU2gvK2VHOG5sKzV4a0t3TzVCSmMyTUNOREUzZDlqclFKZDg2ZjdwWGl6RUQxTmZOdis4RndZL3dwNzhUTjlWcVR4dHJwSmtuakRlWGt4Q0szMVhpSmNjQWpiTHB5NHNSeEVhc0p2b2FRSXNjakVmbjNHQ1V5bXFxODV6eEhhcTFsQ21UWGI2SmR6Zll6aFowY0tkbUhzNWZlazN1ZFZQUVFuQlRpaWx0SEZtb0ZTSXg1ZGZyRmowNkFuWWFNaWlONVNKbUJ4bHNtVUxJNG1PSVNYR2s2Wk8rdkVNczJlUGpHUG14Y2RoRGJFWkQxT0xhYmZ0czlqWVRjNys2d3h3SjdNTkkvU3NFNEgvSzlQOFNzaldCbUJBdk5GMzJlZTdHUHp3Z05UVjYxRnRaUFlDWldkS2h6WUp4K3c0bWNwcUNtUkRyUzgyVEJxakZrQ1piOTNxQzVaYW4xNFlKSVoxb3ZYTUcrd1pMdmZqSFdRb3VlcEhuZ3p4TzFoYjdZU2kvR3NyR015NUt2SndRTFBoZnpaRENxMG56NVNUMGV3d0ZacTFmNGZoMUVnRUd4Q21heFR3RWoyVUFsWVQ2RzJPS21GU241djY2aUQ3SndTaWJwSG9lOWQ1M3J4U1Z3YXFFcyt2dENIcS94b1ZiTmMyUU5ka2loUndYRDZMdU83UGVYRWl0UEtiVkJOZjUyZCtjTmd1YWZ1UHlUSVU4d2JJeWJ0TU9HSk8wQ0M2bDZUeHhENVNaa3Rmdm9vTTdZNGQ2TExaUjdzejNyUDVsaXh4L2J2ZXJJNG00c2lvL3A4d3o2cEE0YzlzeGFybkJNcXZqUzVWdk9vYUpRc0gxbDdiTHFYZzNRVW9XeEtEMWxRRG5YcGtSaXhPSWdreWIwWU0wTzFjMkxUbVBlcHZVTHNQNFFqd1dCSi9jcUFqelFYbnI3bldtSC9pb0ZSdTdCZWxJK1E0QUkyNkRLVDBxOC96L25sV2dKZWpFQVZ2bDZtS29EWXJFRkFZYi9nZzJUNEJSL1pocGd5dlNjSEMrd3Q4b0dPN2gzcmt3Nk43WFJvNWpRb1ZMRFpXaWJ1WTd3VEVKMzUvRm5lRkErd003bWgxb0xqTy93dGRwdjJEcURydlhWSVB0bzAxdjFBeEpLd2xySytHUWJFMFhIMXN3ZnR0TUozcFJINWp4bWFGN05KVEhPcUVUM1RrNUk2cFBGYk5nWDYvYmhyUmEwL0tWbjhNZ0dUUDZVR0luYnp6V0JqYzRGTVV1NWF6YTZGSnVMcTZQNUlMQytpQ29GT1duR2Y5TEVldkFiT09EYTUwMU8zUk1YSFVlNlI0R0pVaWc1eUh0Y3lwTCs5bkt4THcwam5BVXlIblFBYW1UOXRPd3ZRdEZVa1FnWHJxQWs3eExlSGhxUlpsUVZPM3lEd05DUkJYOVRnRFRPLzVCRVZqZ25oaDlmVFlqNUsvQkx1QVZTaS9TVTdYeW9IU0lncmMwbGt1YVJSRjh2NkFzQ1hFdHMwcko1cWp2TW1jZkU5Qm8zKzZpbGJPL2hUMTNVMCtROFY0aDVIUUVYZDdUSk0wMmR5MGtHcmJxN2UxQlZqSGJMNCtYYW1mYS9USWNYUGlhd2lDVnVIaGNCeEh6UFNodjBXa0hGVXVRazNkV2RpV3ZrVlAyWVYzSFc3SVlqNXBMaXpmdTBJSXhwVXhvbWd6ZGVySGIvUUxoN3FkbFhrcUw0aVlKRjFoUkU0Rkh2OFF5TXNhaXRrOW02MmdmS0JnSHRjVVJkOGgyUEZDcTVYZjh0WVZTMW0vMkMzQmdPYW5wa0ZscEFPN0pCZDhyREgrVzRlTitUejdpYlN3ei9SQlNvNHVtdGw0TTdEVy91ckh5Tlh5Q1N0N090UURQMEEwaEZoL0tZTTR2bEtML0ZVdHRlU0NPSEF4U1lQV1A1WWxkUGpYUXlDZC81UWYrNTNIV1YyR0FNUXRsbjhnNzRFZDJWYnpCTEJMcHM1RUhwY2hIaVVGOUkzMTAza0x6eEVGZjdyQWZkdWt4U3Rsc2o2YUNBYWlJdjZiR2YzNFhlcnFRWndRaGJZUi9vUkhNQVdkTDRBcDBVK0dSMXVubSthdGpBdy9UaXlQTWliWlYyUzgvb2JVbnJ2TjhFL2o3ZFdiMnQvd0lTcER4Vngvb09pYlp0QS9PbjR1WUtRcWZ1d3pKQzRFTFdyVGk0Z3BTQ2hEQzNZRU1rdFU4TUtSZkZVOVN5NXdMVTBtRVVFNzRuV2g5dnd0Q0RyNS9MenFCeVhvQWNYeDVyRTZ2NFNvU1ZRVENuQzZGUml0aFk2cnBOMjVoak5McW5la09wZSt1RU9qdkJuWElYWC9uSngyeWhPRmJGbDhUMVl5aHNOdnAzVU1aVHgxeVBJZE9WVkVtSWhJdEgzQ1d0RGN5Y3pqbnZvaWlXMXRCSkU5dW5TZlhVUzA3dngzUjJKU2thUlZ1bFlqSlpFbmNITUMzTEJyL3YyQStGdlFJRkl3WHJzNmJkR25sQzFLQ0pyeVVrQWcrTDhVUlVCWGJDbCtyMlh3aFVCYS81aWZoRllGKzhZdU5qc0R5cFVmYmNiVEprclRFalFuUk1iMUtUUXU1Rm4xMmxEcUExQUxGUStLczB6dGN1M3FqWDN2eTBUTmVZaW02Q0xmN2ZlRTZLelVLc0JaRlNzV3pYdjFhYmlJMzNhQ0FWL1YwWkJsbHV3OVJ3Sit1U2pwMmVoOEYwMWlkWTltb1E2Nys5VEl1MlYzcXRTclNMeUU1Mlc0Y0c3Y2RwdWlCUk1OK3JqSFh3Q3M5djc5MURxMzduNmJ0MGZObmxRWk5yTVo4WnZZRjdhT3dxb1VERXhzTGNic0l6RFdJdVdJc3JFYWhPcy9jWnlhSnZtcUF3SC9sNzB6VU90cUVHbXBCU0tvNkZIRDhmL0J3eS8zOE91VnF2VXJRbHQ4N3liVEU4cGovMElvdXllUXFuTTBCSUNUS3F3bTJPWHhDeDh6QVhvekpJejdLKy9wUUxETFoxaGowVHZ2QkRRUFNaL2U2VFYvc0c5M2NiRVFUS2lQaU9iWUVLdU90eFJqajZsNEZreS9UV2NoVFN1NXlnZlFUUVlJR3hCc2s3cXZsaG1GSDVCK2duNUxBUXlNc0tnVHhIeVRVVzFPTTVMakoxYUdrWktRdm9BcWNpTGtUMXI5M1Nja29YVTNOSjg4OEdkMmVkQlozWEhvSm9JUE9PQ0xZZUVEUllHZFQ2aEdEak5RSktmT1Bld1pRVkllY1VXSUNPdDRhQWY5Y3g3VmRSZjJLRWdidjl5bUYrdDMvL3h2U2JTeE5VL0o1ZFBaKzhmZEtaS2pQcnd6M0d2TUlWWG9DbFpzNWFEcTJ4S1FqUDNTNmRZNE12aFE5VXJSMWNaWklPS2lmVXFwaS9wVEV4MUtoc2F4VHhpdWFyc21zT1ZJcDkycjBPb0RjMU9VZlRLUXBjeFRpTUtSUGkwb2ZzR1Z6eWtJZVA3QjUrTlFqUmxYcXRqeXh2QTJJcjVQNFE4TEdRS2tuMnJKSkVkckRndG4xZitnVHZMWHB5MG95aTRrZ01kekhzd1Iyc3RVeU5jRysxYThQZUtKZXZucldhNUpsN1dDWmJieFdoZmhRbGZXaUJxNkJoS21Sekt3U1B5UEVBYndEZ2djRHMxTHB5Wk0wYjdiMzdWTnA3bkNuRVg2MjFuelF6NjhEVjJidDlWY202anVWZjgwUzhFazdOdSthbVJpMjVpOHdoMHpQUUxRcTlXOVVQeXNzT2NacFB1dnREU3c4NXY3VkVYL1RGRG12TWNBWTk3OTFvdlA4ZjV2NFEwdmc5QzdQa1paeFZLQ2trVnJPUWxwckM2QlBESWcwNVEzQm01YTgyaDd4dmtxQ3NyTU9vMElsQ204KzgxKzhoSnlxZHZCaC9BNTRIU0ZuWDk2RElLYW1xVmMwWGxJdW5xZGZnVk1STGlUZlUzVWZyOFNzZ0VVVWdtVThSUnBTZTIvWVM1NktKZG9lSGdscXJwV0s4SUY2SEJUb3dXemNmYWc2MWFsTVhTZ3E5dE5EN1hXZkJxS3JwL3p2akN5WThha2drZUxhQVdKNHJWVzdGNUJwb3gxUjBzVXNPNzFLRUtDdnZzdFdNVjBTMGdZTHBqbHp1L0JkZ1dKeU1ZYzFnUkJMQXFnNXZta0tjM1hoMHdDQnoxYzdQZHFkZUtDQTAwWjJIVDV3V2pOM3ZPVUp5bnZNaU5MeXNMMHdtdU5mL1pWdVhtM0NvVSs5K3BOT0RyWGpqQ3dCRVdsdGVQMjFZaW1lWkVUZEhtUWV1d3dLcy9DZVdBaWwzTzVKN2RYaERTQU1xa05kWmdwTUtTY0I4UExmRkRRRC9KNmh4cjVhejJsdnFNbTR6aDRuVVJnMTJDa29JNU1jQ1luaHZrOFIxTEttTVgveVVWOTg2NFRLVnkzSkFOVTQ3Z0hJWm11MW5NN2RseUMrU3ZabXdZVmpEVWhHd1ZXM0xXdkJlR0FzOFdDNkE1S0pBZC9vU2JlN1M5RFhlUjBwK2YwRmxLSk9TRThNcW5QbWltd2VDK3NuYmtXdVY5aXJzK1J0OVpaQWp0UDcvVkdQdmxIVEJ3Ti93SmJIM1NtMUJJRnFLYldSd1JYQ0JlL1l2Y1NreDVIMVFIZWl6ZDd0UjF6SWczMU5SUkF2bnBxdUFTcFVyaW04bFpWVitoc1JNcUJSdFBFUVNxTjBta0pZM0s3TFpXMm1qeXRzWWVMOTJvdGM5UUpFT1JSYXpRVC95RUdaWXRrc2wzQ1ZlNlJETitlQ0tVbFI5eGlSNTN4eUtlRnZpT0tCM2pKaG05SjFhV2VuUFMrVkFFMlFHemRVbmcxVStsVk5zKy9IV3Fadm1XbnNaT1VMaEN3dS9oeVZZb3E4OXF3YU1jbUxGUkNXaHdlckFVRjg4OVpBK2Fxd2NsYTFMV09CR3hzZC9BUjBnV0ljN3ZVbzNjVXQrV1EzLzF1NUQwWXMyVVgydTNYSVZYeG5UVFFlT1JuVGtqYk9oOFJyWUFJQ1ZuL1Izd3dqeVIvdXM2VTJqdzdaWGRGc0pGU3FZWTZCUnIrS3N1T2Raank3OFcyZWlBK0x0TWRTL3VQQW5EVEowdURmNURreVlYT0JVZGJOODZ6RWZERit0VlQxS1o5ZGM2c0cxMW1YYm1mS2ZGMFMxQ2IwODV6TFV6akZ1MWJ5QTl3dDJTVlAxaVJhbjhOLytnTVUyNTUrbDluemI3TGlXRUlGSjhSQTNDNTI5Q04yNVNmZmIycUlRWE00ZjdsZmRucWpJcWZFMUFNRk5RcVB5bkZBU2kzWDNMNXZVMnVnREJQVVM5UTV6QUxkVmRUQWoyT0dTY3NMSm1raWZlcmFHbWNnZW1wcm1VbGNSTk9VUWNvbVo2NU5BZ3EyM1IrV1NGbWJreDlJdWpZRE51VElCeTFFc2x2VDViNDRTMkpoVzNaR0YrVjFKNm14MHN0VnBRSS9WN3F3V0dkVnBwODE1RXYzdlRYV0RaNnhFc2hodkk0S0dLZkxHOHdXMDZaOHdVZVBWTVdiSnRSSU1CcURzQ1ZaRG01UmJyNUVVR3RrclJlZEdydU5MYU5wT2tpUzBQSXlqMVdEVGY5ajFHcXo1UHl6TzhGSVBBVVJSTUsrQ3FPbStWTFpETXdQT2thLzZQV3hZayszR2tlNXcvaDJ6emlWZlJRN0h4RXJRNHU5cHoxZTg5elQ5Y2hFTG16SkVmdVZ4UUwzdFNjSFVhMFFwck5mYVl2R3YxVHNrNW1SeFhjdTdHb1E1WFpaWVdhKzRNekEvL1V5ZlVMaWlETmkzdGFOV3ZMZFJMRVFsdTVhWWJvUE5rL2QrUFBCdElTekN4aDRFZnB3QWlxRC9nNzdwMVRIZ1NnUWw4Mm9mWTNId09DYW5aTWlEVm10TmJ3VFIrWHh2eDV2dVh6MTVtejBCU28zOHc4Q0lOT1c2WVBDODBoL2NOVkJ2M3lCUERSWWgrOG1UWkVZN0Q4SjF2dWpib2RSaVNEdSswdHY5OHNld3BTUDBCSzJ6WTFWa0xyUmVuR29NTEg1WU0zUWJ0OG5FaXllU1ZRNHF6Nk9SQm1vcjFWeVRWYkViTjd6S1lvQ2FsTTBtUUJ4VTdCdFl6UjNaa2ZMMEtveTcybnB0S2ZyT3lhRXhKZFI2bDJzNlF5czh0OVMzejZUWFExclJNWUlsN0ZUZE1CNnZUcHo1bHN3ZDZMR0pTSlRVRHZwWjlpMHA2ZXZlbm5jb1VUNHpNbTFuenRRM09rUndiTDhRZjFXeXhUMGZhblY3VWg3OFl4ZS92KzVuNnlHUW9UdTRmZW1wZnpPMVFEYThYbGlId0ZBNjNBc2lqbzJkVElZOE1veWFuQ2gvdlkwNURZSi91Q2tIem9GTHJHckVsR0JzUmlFdWluQzF1dHhpcWJYS05PcmR3bG9QdjEzY1R1OXAwQkg3TVVsYk9PRnJ5MkNwTnkxb1dDSW5UZnJEc2FDVk9pMTFtdkdDV2lsNGZ4RjhGRExEaEMzS2xCTHYxaUF1RFREWUkrVnZWZVhmQUtVTThjc3lySUM5KytERlBPeTZRR2JRNUxxYmtJZGV5d1JPSjIwQlRxTDJBMjVGWjduMHhTY2RhSEt5bm1mWWJpNXVqZDgvNGhkMXFXZzVxQ0IrZWUrSWxGZjVRNGJ1a2p6eGpOQWE5SlIyM2NmTUFpSHBpWVd1dVMyeVJxV1lqSVBWR05oZTNmaHZNTnRaUGRIVzgrNlU0QW0zMGpRSDUveXJ4bmJGcmFXRm9yVWxDS1gzZnFhdWJ5b2RqTGxjRzY5VlRSMXdjUjVzSVYxQzNqN25lN2xRdmU1ZTFPazVBeTZTTUNCc2syU2FrVlNNRXliM3djNmRwOHFEV1orWVdqTXNCcG51QWJ2QzRuci9aMFRib0t5QXdDOUMxZlhXVXFsaXZxb29nMEFYTjN0bWswMzNVMW5LcktpcjcwNGFYcmkwczhkRFk5NnZ2c29RdkdMSnFFeW5kbjcvTDlDZmtxbzlOMytkMW1NOEdvU3VWSnk2WDh4WHRCMEtFc204QTJFSFVuWmE3M3gxZDNlV3FRRS95TGdiTGMrWnJ5cTZNelVlRG1xdEJnZlc4UUUwSVIxcDlpQmdYcDV3RFRlc2hiUzhJNWlVWGNKSVJWalIvUFlJcVBGYjZESnRubW01dzBwNEdJQjJ4cXo3VW9jcStFekVDaU9OVUNkbmhSZDZobFVyVzhsRW43UjJMMGlWZ1hhVWRwV3lnTm1vQ3Y2bVQ3SVMrVWEzUnV3L3hhN0RoZkZQSVBLN25ublArM0ZReEcxN0wyeGY3ZUVtRFJvYm54RjIwYkRTVERiaXZhYkxEQmJOazczL3BWeGJYdWZIbG9tYlU0UmJBaVlBWUFTUmhWRWtpWHFIRVRsdzhSVFZDNTY2UDF5NTV1NWhNMkQvQjI0R2dYZlZ0TUFoSzBONkNuWkVCODhVYmlIczJ1YS9McUdGUHYwS3RmYkpJUXVPYzBCNHQzby9YRjloSDZxNEp3eW5QRGVkUm9QY0ZLekZqeEM5ZGlxNDBCbGRwQlp0WHJkdmFLQTdKNlc3M1hXWVhMZ2xXZWY4VmYxWEZ0SWl5bjV2Y0VMKzJjTmhvenpMUitTUEdTTWIyYkZVM3RlUVY5OVlrRG4yUlZKTjlWTlIzMzlHOTdXbjNJZDFzU2RtVzlaREUzZ29mNWlKb3djSmVyQmlRYW40TVNQdjlJVEtrTmRIR3cybUhmRHMyRzQ3aEpWRy92WXQ5bm9mWkp3SmVwRFhIZjh5OXNNUVBoZ2xVYWk4aEZncUg1T3R0UVNhUGtneEpjdUkwb0lsamlacGM1RUNUV1FNekR4bVQ5V1UvU0xqa1ZlSkxmSkJmYmViRzNaMkZ1RndPSVAzd1JyWDlsMlo2YXNrUHRSTjZOK0JiYTVOa3VGcXlRZVdGOWxGZ3V3V1YvUDVnYmNtOXJNTDdxcHViVDMzRzQvYnVzMXdqY3JmK05CZW95SEtlREZrZURoN0VRL3hKK3FPVWJVdWVLK25mZ2FBUWpPR01JaW1FYU1XT2RNbVhjK1RWV0hqQmxPV2lWYVE3bXZzNkJHS3pKT0JNQjQ0L1EzbUpZOVE4NDdyNldwdHl2cFdZSWpva1czbzlBdGhCNEFESjUwQW9MRFk5Q2JpaG1idVhTdU1ndmR3Q1JWU2VHN01GUU1qQTdhREwrT0xiV2x1S1BWc3NnbFB3ZGpjUjRNcXRxL3JQK3pzUlJCWU5yeWFPTElVSk1sOEY5NUoyTVdHbTd6Z3pnNnlVOHFGMFhXd1BFTUljTTFqUW5wWXhPbDd2cVkvcUZQc3liYThmVnBLRnp2cU9nZk1BMzU5YVBocEhMTGU4WDRqUzVidVByT3o5d2lOUGdrNDBZYXhLa2ZZQTB1L0JZUGkzNHRrTlVwWVAvc2VxVHgwK1BHdnExMUJiL25HbU4zUjVFU3FSdHZUZTYyakF0aFl2d01GVzNvWUUybW9CZHA5M2RzN3FUSlJ6WnAraWp0NkhpVFpCQ05FNjZuNHppdW14aGxydnVKaE9vVFFZNUc5ZjlBakxpb1lZaUhEbURFMmNINHVPeFVJMUN3QURmWHVwcjNib1pJTElvOEh2OU1lN0hVS1g0aVFWZzFUWHJqWWw4TmlaMWJTbkhxekpRcUJmemhKM202UDluUW9vWHRJQ2tUQWVFREJKcklsNG5ZOExnc3lLSXl2a2locE8wdmFKbTlJTStHN1REQnlwdnhKdTdoUVIySzBialN6bStuV3FMWnBnYzd1UkFIUlViRjBVVmtsS1Rob2V5RTArRkpLTGoxek1tTnpvKzdnR2tCUVJ1YS9HVUpUOFNpUkprRWNZU1N5RDIxMWR0MHMxQzdCRmpiUUQvb094cnBDRWlZekxaQllUTnNQQzhka1NKc0tjRGJhN2xiYi9FVlg2N1lmZko3bWJ6cHNCc2ZiM1NXMnRESHl0VnRhVWtQUkJXeDFIOU42cmJaTjhzd2ZnTW55M2tkb0VDRHhHWnRpeEhRQTVBaXhMeXlQRUkrTWFHbWQxZmRYbTl5Z0hQdER6RjNtR3F0b3A0VXRMVjhXRVQ5bGtQTVJaNldCakFucmt5RUlITHhaeENLMVpRQTJaemFjRVFEZHAyNDhoOW5zcjR6S09kU2czOWxOM3J3d3hFdHNKalBadHQvS21RWG5qOWlSaFdhb25tQTJneklVUkhjTERiZ1IrWmlRcUIwa0ZvdC92Q3JOQUR6WVZBZlltY3R4N0I3MGxHYm41RDNtc1hGZ3lXN2RDY3FIL3I0R2JPdHpPQ2tKR0V5NmJxcm8zTU9UM1VEcTA3cTZNbXYvdEFFVlBJYXJyc21GUFBFdTlQTEIxUU5vekpmb2o4Uk5ObjFXMXBtemJyaU8wNTBReGpvY0p1aUdpaWFXa04zVlRWTW50VGY2UmtiMG5MSForU3NOUWlsb1c5WEorTVExWHdTRHQxVmx0bzd4Y0VxYy9ndkxUdjk2MnJpRjRwVFo2WnJDWU9lT2lYMnh5aWNpemg4alFBamdld05YR0VFejhwNXZnVGY5Qk5Md0RBWjIxRWxCeE9zQ2lOblczQ01uL3d0SjFRblMwT0xER3h5bnlQSjNYQXEyTzZGQWNRbkVnanhnREU4ZG9xUi9YSzRTR3p0bG1vNDRqQlcwb2I2amxqM1RqTU5EYlJ6YldoWHI0TmxRNDdnOC9wbWU4ZFFRcDg3dFk4TE4yREd2MENlbi9FV0c0Y0NKeEI3cTllVW5TUDRLNmdkZjlkZUZNNDU3TUNEbzhOVXRhOEp0Mll5TWZTUUw1NDhSanM0Q0YyT0lrTHJTU1grc2dRck5qR1pXNmxNWlljWTVNdllDMXVsZXYyQXJyTHRjbHZWeFk2RjV6d2RvRTQyKzJCRGNmQWNNM2hJYmRzL05GSEhKTVcvd3VYRmE5a0RqMmpDZHVEQlhWZEYwM05PcHlyM3M1QnpsQXB2REVVbjBYYWNZVnYwUGNsRUQzNnp1clNWVmhaZ3dOSXNJNWlnU2NoWW15bEhDQlBxMXJJZkFoaUM4blhUZ05obnFNQmxWYlhsWHJCRThLcGlLRlNVdW9xTFgvcUdMYkk0emN2L1ZCbitPRHBRWVZPbGR3ZjVsdG5ucW5SR0s2VmtmT0M5U3ExV3dYTEN5V1JYWTdkTE5WRWZvVyt0YmdMY1ErY2ZDa0h3dTREVTVNOThxSXR4Tm5pQWNIN0RDcmdxdlY4UDJnbyt4RXlWQW9NWUFSSEhGVW5MeGJlK0lMSWRaSDhaOFczY1FUdkR1YVhTRi9tc2FzSWFBV1psSDRxTDI1QTE3MDBUb0pjZmMzQ08xMzgzZXVObzFvRk5zalhHVkJ0YzlCNlZ2UTI4d3pka0t3T3Bnb0dLUjIwTUZiMTlGRUM0ZytQMkh3OEJmS21YVkdJa3RwU3RPdDlWR3hqVVVDbFN1VmJ6SXhIQUh3aUhiRHZjM3hGV3AwMGkyUk1taFB2Z1pxN1BZMkJlVzE5eGhCZWFhL1RYaTZjMGtLczdMSW5iczNQMStoVDFWYlRpc1E3SFhNWXpGUGJNbkEzbTc4TEZZdzdMMHNDc244dlFnQzlZUHpkdUdzaHVhTkdtSGU0QmJCWGhwYzYyU25hS1RCU3ZsbXIrOE9VUE91VDFQNzRvMXU2NjUxUkMvQ2tLUWJBdmNmcTlIRDVFY3o4OEpsWnRyNkt3dVMyVUxoMjQxQ3RBNDZvSUZoRGdrMmhGcHRMbXFBb0xMOW1oZ1ZVSnpPMUJnTWM2ZEZZYVIwT242NnA4QWRxWXZieS90WFhENzhaNm5IMVBIME03R0hoeDNIZWdtY3J0ZmR4a2xvazBJMkN3ZXZVeFlJNmlRN2poLzVCbHBsa00ydFoxWTljaVV4Z0lZNW5QeXA5VlVNSGdGMkx0dlBwMWhsUlZvTTlsN2FiMUFvdFRGU1VaQUc2MTJCcWwzSEFjejM3R0xIMDdobDNRVHJKWEdHSm5RZFExdGtLbWwwcDdTWVpvOUtQWVRJM2JKU0dIMytRUWdDRG9iSzc2OG9kY2tUK3hFaEFhaU9MYWd4NHhhb2RxSDYzTGxHSU1kQzJRcWpyRS9LRVF5TS9rWXFQMVQ2ZzNQalYzTkZWMG8yZElEcUVQckJWOUl0RHoxc0dvU2dqZ1JnOFhvNzh4MlJEZHp6QTMxTzFieXhsMXI2SkZQVTRKWVRENzJRRkZicnRmR2I4QzJTV0dnWGh6N3hIODNUSVNEaE4ycG1oV0gyR0VVTzVUM1ZLSzdUTldWUXlFREdWOUs5YStGUXdScXh1QmNVWTc1ZHd2QXFpS0xPTnVwQUlhNWt6eXFhR3MrQnVWcC8zSVhTNndaMnFIMGxxMWhCUi9kNU5XOVNHSXFhcysyRXlGZWtmU1Jsc3c1M28xbUNmbmh6ZENyQjdmM3E4a0lkd3JoMDl5c1g4bXhQS0pScGdqR2JzK0I2eEdMYm1lUDdSMGo3SU9Gd2dnejFESWVFTkFYNDF4bzA4SVNXYVE1YjhIQ2RjeHdqQ3dTd3hrMnRSbmlCZ0tXSm81MHBhQm5uQnJrcHd5RkNxNDVHRW14SXdlc2lCWll0NjYrY3UyQ1d3YnU2S2NLYXNFV2ttOUV0c0doZnpkYXlIbE1IYzRqL1QzbitJNnlrZ21lQTNoTGRSR3hXTmdrTWVqWTJkbjNZZGVPa3hIai9valV0aHdacWVUM2xIZHI5QUlTVGFRVUprZWp4TDV0NDdKMi9QQ2RZY0NLakZYc0p0RkZUQzNCRDlBbU9vYnZOcVNjZm9xRmNWek9VYTFGd2J3dFpvdmpUVkZ4MGtHemFGNjlwcml3NExQR3ZrZ0VxVlViTjZ2enBCeG4xTFVRYlV3TWZESnE1THNLVFhCQjVUcHRrS1JoRFIraGk5Q1g1UWRZaDhVVzMxNnZhZklXZ1REM0t3YS9VTnRyNGtGTTZ1WFQydjhFU284d00vZEtaVHBsQTlRTXFoT09ZMG9LV3N0MEJETTNjMnJTNy9lWldZMTk0WmY3b01rNnA2bnFXZUErcUZRdU5PczZlRStSODkwU2xJMGg5TzlSc0lXbXNqVy9UU3FYeGJVVUxEc0pQZDZwa0NsVDJxNCtYTXpzcjFsR25xRXBQV2oxbEdHQnVUdDlmenZhMjdZeWtZd0c1YjRla2pMaWlraHpKN1hxdGd6ZzgwMFRKaXJzMG1lUWcyQ2oxT2RHK0VnSzNsdkR5VjdHSzRaT0tOSERXT0FlREpxTkM5djE2L0p6WHJ5NEZ6WEZTWEtOVktMbWYyQ1VpOHorVytJenpWbmxMQ1UzZUcyQXV6bjhwbTBVc1pNNC9zNkRvRE5aVDhIdlNHeXFlU25aZGErY1lyS1cyZkNXZUhvY0VNUThWdGhaMmpDVGNNTWtBMlNvbzRtTUJwSGkvano2V0hjWlFnSm9ldVdpYllEOG5PNlN4aEZoWVhzZHdXaW5IZDVWVmdJWCtNWVdJa2hhTnpsMC83eG1iS21sbG9nT3ViL3Q0VU85aUFtQkNUdGNSZTZGSCs1UEhoUkloNFFpNG51N010eUhMZFFoemJmMWFRWkhPZ21pQkpBdmtDUDlEOHZoRFNRRTZybXFhZHNEVTg1OVJ6WlY5WlR6RG9qZTVkR01XL0UxZW93TVp5ZWoycGt4TXdNSFJhTjg4TVFDdldhYllibWYwQ0NpWDZlZjE5a201Z1UyMmZKdi9CNG1LQnVnSnJNR1JKNVJLZ0N5cEZRdmc4WHJzak5MdkpOVmxhQ0YwVWFlcDJOdlAraVN5YjB3cllHRDI0Y1NtZHVZNnVZV2Vpakx1ZkhXZmREcktIZDFkbGh3L0Faam05SW01ZnZ0dXRtSDJGSC9WTEgvMk9kQXdiVC9SOE1QYmU5VXRpa0srMDBlMENEVkJzblk3R2ttVElYQnRDZzNQWWw3ZzJDRFdzUXFtMjlwSjJBTXhSZXR2S2JQRzA1SWhiOEhONzBlTnM2Q1B5eWlHcTc3aGFhcXdVaXBLSk9jc2JlZjJreWp6bEF5dWEvNlIrem1JMlJLOXRyWWVmKzl2NjJKYk1CcmNtYUdYaGJQZlliMlh1WkdIKzRIeWVHN3pkZHdCZTVTUkhjZVlYOFJQbW1STXo2S3AvUURFeDVwNEhpNmlBendlanBNUXhYYWE0SlBJVVlsVzBFa1dCd3M4aXd0WE1WLzk1Y2c1MWtHUUJpUXZPdDhYL0U4QmhqNENsSHlhbWNnRGQzQndVNkRFZjN2VFp0anVrOXJGREJwVGNnQkluUTNQT1U4WXNGN1A5UU5OTWdoVkNONE9mRVhxNVdKdVZSQzh6Zk9kUnlqMzM3QkVENFdWanp0Q0t0cGFPT2ZEZ0IxRk1yNTM1RnpiajhBdThVYmdNOWIxcEJnSml5TEcwR0UzU1dqTEVMZmpZUlV4MFZKOGZobEQvTnFhclJUb3grVW8vMjU4d0hJcGp2Y044alQ1RnY3M0hBQitZK2ZROGNMUWZGNlMzTHlvYzNrOEpTRXhTZDVvQWZYQnZ2ZnArWEU0QzJmdFBXWFl4L0V2ZGZuUXh4YllldnBEcVc3UlhhSU1pTllvUFloRHJ1dmpUaUdkcDlXMU10MDYwandpaFJJY3kvOG9YRE5IYmorUHBXWTl6MmpyMStvYjd5cFRHKytEWFMyZWpRR0ZBcmE1b1c2US9GZmt1OFczUnovUEMrekpuNW5tcXJzb013OFZWUHVGNjdHdFhYcjhCd1pOaVdyRjlnQzYzWmVJL3JxQkg4aWxHSngxTTh0SUdoTGVqTEhTTmtCb0ZaNDVtbDM4elUwcytPZHNqbzZGaTRaV0g0clZ6cGJhMDAwT3dsaUR4RzlpKy9hbHBjVzY5MUVtKyswMEFEZlNTdWt1TEFmRGgxK3docm51VDFSTDJ2L1hEa3dETlg0NW5EcStmaUFyZEhGYVc3WUJrc1JkQ0dNL0Y1cGlDNGRzOWNYeU0rUDdSUWQrblZtVXZ3bWdkRS9rNGJmaDZuUzJad1FweC9UN0d5Nm52ODlMSGpNbFYyNGV3SzdKV1ZyNHFXNlVXSzE5TGNVdGcrWnZSeWVHV1Y1Q1NrTFMwb3RVUjZIYm5VVm81VSt1Wnh2dTY5RlErSnZTa1E2YW9lWDV6dGFjcjN0aFNZYmJTdGp1dzJTQjdiZXJCbEFnOGxBYXM4UUJ4YmpDaWhVZVFpcnJYRmJNY2tvdmtwaEhIa1ZMY3ZwUElqUVEwMkpTOWZTcndtNStkMU1GM2grWFkrY2k0Nm9lL1p5ZStvUEJvclpJcU8zOVgxZnlkbko1dllkNE1wdjRBTE9wMXZDeUU5UkM2akZpLzFmSmxoVTlVRGJzbUlzVHM2QWJ3aFdMMnljeGNrTkpnZDN1WXRsamdCTjBjcGRlWFNnMW5SY0hkNzVOc3AxS01pWG1lN3duSndjNE4wSUNpd1JtY3psNTZJdk5RWEl3NzFvaFR5b3hIWnlROHZaMmFzR0xzNjB6aHhvNWpEcitkTnEwQ0tIZU5tSm9qR2hjSFd4ZS8yNDcwcWY1YjdGcmNkM2IrcFZsdkMyTTBFaVpSamtveGVCRytXQ05IVExYWTFRc3BneTNZWmRQUHdpcjMrQVFMdlhnRXF1ditMQW8rL2J2ZHpRSkxnWU9HMFRHM21iUDFISThhYWRLcEtwb1I0Z2Z3cjNFQVJ0WkV3b3JEeXljRjJnVm5oSlBSUjJsazY1ZjQxdEQ3aURETUp5WUFDQU94S1JMbmVNbG9KOHFhRm5WdGVBQm5WdGhENE5BeHNyMHQ3ZzJoR0hHZGk4SHB2Y2JucUxoT0dVSVkwNm5Qd0czdEhkRmlEcEFwQ0gvTkZOdUt5N2h4UmJhYnVuMTdDS05iVmV2dWxnMEFzdUE5cFpxRUhkSWZkTjRWZlJHNjRIcmIzcGpKa1BCODRxMGpjamp2OUJOYldPYlJhdm40Z0hnSHBMZitETUZpZkU4MHNvMUVGWFNVaXlwNnhhUFVPNVRKZ0t6L2FBN1Z3ZXhROFpuMUpNVDVMRWZkYzhRMEs2M0Q1NW5UWmtpQnRkTWhsZGlaSE9JbHJHdlhRcnFGcGVZNnUyNFYvRkxVSlQvM0JaWUtRdGhPam0ya0JrYytRNk96OFlaUUFMU0J0QzBHZ0dpVzdIZU5kKzAzeVNIeUUzSjRTTi90VWE4V0tiNTRRZi9KN2gzTkxSckZHZEJvQXh3L1B6dkxNczZMQktGR3kwT3AvNEFoSDRWZmJuYWNWaEM5bXZpUlovK1ltWHBiUU1KenUrMUxLdXVscldBMVdEdDJubXpuNTd3MEZLSEJwSm1NaGhqbWQ4c1FkRk1XckRFUUdjMkNMYUJvV2wzZ0FCdEIxdi9adHpiOGFBQWUxVENWTTBGQWtJUFRWTXV3UFV0aVk1TGx1OTZLcElMd0VPcHNvQVBUOWhyQzIxUkVEcU5TMzBlUGdic1JKajJlUmxzNmhIQklPOC9jYktnaUdpS0N5enFnSUdyZG9PZXRwZ1FlWVAxSnJ3QUNyV1lENGNiSHAzV05aSVJzT21EWW4xOXdrOS9UZ1ltVzlUWEQ2ZXhGU1FWYmxBcllpLzJ4bXVDTDRQWm5LOTRJYUpxUmlwb0V4ZjJad095UEFyRUdUYUszZ01mMnV2SUxTVEZYeFlRM3Z2N1RxUk5JRzREWHIwVjBDc2JmU1crUXRaeExnVVE4V1Zzd2NOa2lNNXpSZWQ4TjJKelY4S3Qvc2lsUXlkYlRhR2hHbHJiRFlRdXBBc2w2WEJMSmZNZXdRL2k1T04zbFI4S0tQWURzdzJaZ3dDL2lJNnpodDNjMHlFaDJhM21JVkdZZXFlemR6US8rdnVJOUlYd0dQdkFDTlBGQURWdmZiRFR0VmZNNThGQXcwTElTT2RIRFVKL0g0M3hRRGlaa2tVQnI1U0FVZktYcWhuM3ZWSkRtWW0xWnRHMXg0S3VtZ0xTNTRoeWpkVkcwQ0pUUXRNTVhkZ2pST2Vkc2tnTmlFVWN1aE5jZUd5Tk1RY0lsbTBEMmN6OWwrQ0lwNlh0NHBwZTdhSU5ZeWRqQVBXdFdoZ1RYNVI3Z2E0M3VsbUdPL2N0cmNSVzFmdG5GUUFsTnhyVVErZ2RZL0lOaVFaRi9HeVZaT2tMSjZBWGFrZFpmdVhsbzFFcXFmMFdmNzVEN1Z6QlVDRUZXbHEyRUNCY3g0d1d1K0N3SkMwRk8wTWdmOHVTVEVoNEIvd1dNMHdCK0xvSEtJYnEyaTVrUWhzMmFWZEtrTWRZMTBPMFNUSHdkcU1yQ25MaDFiR3JKcXM2ZzEwTFFhVEtGSDh5ZnhkNHlVYUFsL1hGUGdaem5TZGI4NnJkNU9RVmtVK3pYVmZlNEpNc1FpRytQRVhNTDVFb3hDWWt2SU9nRUxpM2lIV2VNM1VBeHVRa0IyS3RNUFpiOGRlcTFmV0hWZmFQRENneDBLajJpdThGR2dFejRlWEh1U0NPZUhrTGptbHZ4bHFqWS9uR3VHb0VlRGo0SFl3N0ZuZG9ONE8rY0RKdjArbW90ZVFkUERvZngxQWxZa2RoazN5b2dqYmYvbXVTcFZDTFFEeHV4RFprWkZuWHoyWStMdFB1UmVtQUsrUlVxUER4S2dFQlhTdFdveWNndGFraUp4QXptaC9jd3o4K3VBUmJ4d05KL3laZ2hGZGNOQjRDcmF6QkdITEJBTDBCZis2dnRoVFRaSS9iakVHUEpOV2k0ZWJVUWZVR0VVWnl6OGZSeHdwc0xBYjJualUyVmxkSXRBVkE3UVpDaU40WEJoU0FzOGNDb2ZhVVV3VHYyS2pwYWtlM3RqYTJSSlZOTlFhYVZqVk1mVHYzSXYzVmxxSXZFdVcvNndGL2pLUjMvQXZuYjYvRWdvVzdKUTJPYkwyRmpZNTk4SDBQSzJBRmdiT2pWOTZTTllPclNBcklNaGdmMUMvL2xJMU5kK2J5dmtvVXdXend1bTBNWnYzYitmRE1pODZaVUdiU1p5QjRaTE0xMFRLaSt0RDVaZWYwd0RUZitSWTk3SHhvMm40M0gwaXdLQ1I0ZStxZi85UFBxaFBvck5lbnhyTml5ZGtLUmtvQVhSdWtzNFEzNmVqYWRnY0RrVGFqYTdIM1Vzd0tDNFFNTjhIQlduZG5ldlNFR1lBVHlSWHdjRXBjbmt2YTZsTDJMT1pjVi9UdGpDZnBqa3FaMjEyWGFiVFNMcU50a3ljYzFmNDJpZjZheFBXT3BnR0FHbTlYYXErcG5adjVBV25hMUgxeVBmZXJvV3Flc3BuWW9aUTNuZ3RZSWMzSTRCeXNFVGprTVN5UmNaSU1UMGZnbEJhdjdYR3dRa21MTjIyb1pjWU1STWE3bFhmRUtId3ZKUUIxdnhGZGwwQWx6Z1F5WWFCRE9sVlp0b2RCOFBaQ25vWms2aWZmYnJWMnhqWmE3ZUttNHRSKzJpNS9yU3FWcjArZkk0Z0FPcFVJcXNtK1phTGJOb2hsWWMyM1IwaThTMDNERVpRVlhYVnE1ZnNmblV5SEhIWFhwdy9Xd1h2QUlnUFpWY0NXSmxIN3ljWHFzZW4zTTdsWUxpQ2VKRjNqRzYyaWc1d2FKakNMdmpkSEdEOUdSR3luMStuaEJValViT3N0YlpUQllyWW1CSjZrclBTYzI3L2dCY0VIeWdiVE5JWTl6clJSdDJlbVdTZ0xiM0s3YVRNNlpDODl1RUpUTnI3b3ByK1dBNXZ0dS8zMVNOVmkyb3JSTzNGTTdZQTZTN3hjL0xTeWc2WDlNZG5uVTVMUzlEcEt4cXBzR2ozTDR0bmV5TzZvS3ZhL3FLUGllcjFzVy9zYTRVTjdSdElXWlFVZCtuelU2dkNOYmZsTTR6cFkwU2c1RmNvR3FTa3hIWm1vSzk4alBFcTR4TDZ2b2VBaU1Oc2ppM1hpTzF2TnV4ZHdVa0F4V0dicGw0ODJ6ZHR6akhJY1NWc2hBQ1pEVzZleDdhNll0MEdFM0d2eHd3ekROVmU4WlNGSjBycTJscnI3WTA4YWJaSC91MTloajc0VlgvSm8wMFdmYm81dUpMcW5wUVdidFp1QXExN2EzamRlQkRoQi9TWVhXck1YeVEra3FqcHlPV21FVGVXc2hSb2UvNjIwT1hzNzFZNmF2VUM1Q3E2S2NWSlpNUlV2L3ZsRFZOTEtZUFJ4R1pTQnNxZHRkUUM3TGp1dVdrc3FUSXN6VUF4OUVibEpQNjJGYVgvZVpKYjRrZk93SzQrZlU1S1Nob1g4N0hHY08wMS9Xdm91Qm14WC9XcEdydXNzcnozY3MzbTNrcW5tZHg4WGtjT2JkV0VrUm55WDRsLzgwM0w1T0N6aEJRTFNxbHZZM0UzeWpKL044WGg2aEsybEcwQWJxU1RLZEZlNEp6MzJXL01idE5WNW9ZREtIcysweEwraVVJd0Z2VHVwUXpSU1luM0s2MGptQ1Zub0w2c2JSa0ZDSm9hNzFMRkNxN2lOdzEyUjJXQURxSjVxVGo5WTVDMUJEcWYzMEgyY0p6SEt2b3ZKNVFIOEZSdFE1ektVYXplUjF3M3NBTkt0b2ZZS1ppME82M0xla1RGS242NXVoK0Jwd3hRRzRNYVhsanMxeVdnWTFRaTlFMG9SZUY1MmFBVDdqM0NQOVZtN1hwaVBZbFlPSVR6YXdYZWtxYXc3bkQ2VGRQOTFCU1VuNGdhc2U5ME1GTXYxOXhHK0o3eVVzU2tKT1MveFU2WFN1MEZ5S09uY04zaE52N0pQNHFiUkRucWJaZXpzNDluOVRYTGFpZ2QrRndVZjVZUlRzMFJnNmRoQm01cThuanBlZ0o0N3U0ZHdmcFUxSitoMkwxMzVHKzg0WHVMcTRQcHEraUxiS2NPK3gwdnRDKzM5SlJJWEJRNnJGWFYzRi9YeHVUQUQzaXYrTlhPdUs1VmhTdlBsb3lJakxFZ1ZqbHZwdWZhdmI5VW10S0hGS2N4RXZjSTRrVFNGMmxPWE0wak9mZkE3WnlYa0xtU2xCYjl3a0dnTzgxNlFOVytXUWY5cjgyaXlxT0ZzSmVsaDRtbkJsMS9IT0RsOXJMZnNEb0pIZGJkeWdvV3lZdjloaGkxTitSRHM1RWJoL21zWWFXQzZwbm9ONVhUNU52U3o5THBwRFJuMXdqLzJFTnFUMnltMmQ3Q21BNFZIbTE1Tk04c1NmZFpkSkkzUlpoSDRFSE52Um5waUZUTmFWclhTR2NvUDZxTGM4SFNKY2FPNzFucjNDcm9DMU1vRFhZcURxbnpwUm9nTldiZDhPWm1EOEE1QWEwWmRKOUMwTFpMMVNTbWtMbXlhWTdZRGdVNzFWWjZ1ZDlJaGFvUlRuYTBOUE1lczFTY0NCZ093N3U5QkM3MDRuMGhIQ0VHSCtZTmpLMEVPOWNZVVRURHJmRmZ1YnlWeFRVbE9QUFg3NlBRdFRDUHU2TUdWU0VhNEx5OForQjR5VGV3Nm1Kck90UmNxZWx4dmJGdjBUYkhHaWpxQjRoZ1JnMERWWVY0V3YzTkRHQzNhM3NZK1dDNWJMWUxRekE0U2p6RHRaOExJcklPcDcvUmM1V09zUmtUYTVxZUFJVUY0WTBySlF0MWlVSG84aWIxWnB2MjdDUXMxeW5xTTUxakhoQjlLLzczZEIrUTJNclYxand1cURFTHZZRWwzOC9td1lTSFdyV040clVyZ1dPMzVwZm52UlVMWTQ1TlNqVndMclFCVXA4L3ljcW9UMUkxdnFCemdzK0U2S2tPTG9sMjJrSXVmTWdpa0ljT1FLUDFxMEFFclVxNXRSSzdFTFpaaVB0d3crTmlMQ3h0UTJZaHczWVBqSFJIaEp0UXlkczZqaDVqdE1UeTlKRjYvcDIzQWprdU14RkFabkI5czZkcGxrdGNveVgxOHV1TExrcWpHU2ZBb3NqOVBvSlg4UlFYZDVhMzFUZTNYWnJ2ZStGWmFvb2Z3YmNPeFB5RWdOcEhQakJQT0RlaklMOHBoY0FUTk5CRkJaZnlNR2t1aC8rMHp6MkV3UUNxRzZBV2NUdVlHSWJUNXd3cldGbW8zbFRYUktNSEtZODB1b1V6T1A3UCtQZHNTMTFnV1k4SjNoMTUxNGJjSTZqbGxnMWNibjkwQmJUZm1FcFVETnhWTlpQN2FrYTJQZ01ITHAyZEwyUEo4WFJabWdrdFd4ZGdjeEtUV3RGTEdDZCtCU2MyWCtUbjNpdXRzVVZNelZYVVFtL0RQVnJLMHp2RHIwZDJCbnl1MHRKTUpNdkZHWmUzdmxWT0Z3RmYvZDhjMW1VNXBKayszbkVrTVJrZG90eGNaTzd4Z0pyWTFmb3I2ZnMxeVJHT0dkdEMvaVdwazM2SmFyKy9YcHFyTm5xb2xXc0ZpbEZEWVpxbURjM2RoazZKK09hR0FXUGpvQnEwNnJhYUZRc203YlBLV3FNZmlGVThZajdKZVhRS3IxUXkyUTg4M2dxeUVhZllxdzJ2U2pCZk1qL1NyS2dlM3dJNEJ3Ymlqa3JwMFpPdFJQczZ2cE1KeE4xNE5GUnBaSDgzM210aXFNRkI3ZWl6NEE0T1JCRVZqUENMdTZlZTZ6b0N0aFVqUmk1MlF4MVJjb01EZ0RiT2d2NUxTcWhuWW1EMHRQWHgrY1FVRHFibFRpUHQ1QWhyamw0YXJCcUFyMFZVSzZsN05VMEZJdkNiQWRvR3JqajZCZjlKL3FzTFpjVzFPc1VwelRBL051SHRzZys0ODJhMUd4cDlHaHZEZDE2K0s= [/PHPkoru_Code]class-wp-customize-media-control.php000064400000022275152222507600013572 0ustar00button_labels = wp_parse_args( $this->button_labels, $this->get_default_button_labels() ); } /** * Enqueue control related scripts/styles. * * @since 3.4.0 * @since 4.2.0 Moved from WP_Customize_Upload_Control. */ public function enqueue() { wp_enqueue_media(); } /** * Refresh the parameters passed to the JavaScript via JSON. * * @since 3.4.0 * @since 4.2.0 Moved from WP_Customize_Upload_Control. * * @see WP_Customize_Control::to_json() */ public function to_json() { parent::to_json(); $this->json['label'] = html_entity_decode( $this->label, ENT_QUOTES, get_bloginfo( 'charset' ) ); $this->json['mime_type'] = $this->mime_type; $this->json['button_labels'] = $this->button_labels; $this->json['canUpload'] = current_user_can( 'upload_files' ); $value = $this->value(); if ( is_object( $this->setting ) ) { if ( $this->setting->default ) { /* * Fake an attachment model - needs all fields used by template. * Note that the default value must be a URL, NOT an attachment ID. */ $ext = substr( $this->setting->default, -3 ); $type = in_array( $ext, array( 'jpg', 'png', 'gif', 'bmp', 'webp', 'avif' ), true ) ? 'image' : 'document'; $default_attachment = array( 'id' => 1, 'url' => $this->setting->default, 'type' => $type, 'icon' => wp_mime_type_icon( $type, '.svg' ), 'title' => wp_basename( $this->setting->default ), ); if ( 'image' === $type ) { $default_attachment['sizes'] = array( 'full' => array( 'url' => $this->setting->default ), ); } $this->json['defaultAttachment'] = $default_attachment; } if ( $value && $this->setting->default && $value === $this->setting->default ) { // Set the default as the attachment. $this->json['attachment'] = $this->json['defaultAttachment']; } elseif ( $value ) { $this->json['attachment'] = wp_prepare_attachment_for_js( $value ); } } } /** * Don't render any content for this control from PHP. * * @since 3.4.0 * @since 4.2.0 Moved from WP_Customize_Upload_Control. * * @see WP_Customize_Media_Control::content_template() */ public function render_content() {} /** * Render a JS template for the content of the media control. * * @since 4.1.0 * @since 4.2.0 Moved from WP_Customize_Upload_Control. */ public function content_template() { ?> <# var descriptionId = _.uniqueId( 'customize-media-control-description-' ); var describedByAttr = data.description ? ' aria-describedby="' + descriptionId + '" ' : ''; #> <# if ( data.label ) { #> {{ data.label }} <# } #>
    <# if ( data.description ) { #> {{{ data.description }}} <# } #> <# if ( data.attachment && data.attachment.id ) { #>
    <# if ( 'image' === data.attachment.type && data.attachment.sizes && data.attachment.sizes.medium ) { #> <# } else if ( 'image' === data.attachment.type && data.attachment.sizes && data.attachment.sizes.full ) { #> <# } else if ( 'audio' === data.attachment.type ) { #> <# if ( data.attachment.image && data.attachment.image.src && data.attachment.image.src !== data.attachment.icon ) { #> <# } else { #> <# } #>

    “{{ data.attachment.title }}”

    <# if ( data.attachment.album || data.attachment.meta.album ) { #>

    {{ data.attachment.album || data.attachment.meta.album }}

    <# } #> <# if ( data.attachment.artist || data.attachment.meta.artist ) { #>

    {{ data.attachment.artist || data.attachment.meta.artist }}

    <# } #> <# } else if ( 'video' === data.attachment.type ) { #>
    <# } else { #>

    {{ data.attachment.title }}

    <# } #>
    <# if ( data.canUpload ) { #> <# } #>
    <# } else { #>
    <# if ( data.canUpload ) { #> <# } #>
    <# if ( data.defaultAttachment ) { #> <# } #>
    <# } #> mime_type ) ? strtok( ltrim( $this->mime_type, '/' ), '/' ) : 'default'; switch ( $mime_type ) { case 'video': return array( 'select' => __( 'Select video' ), 'change' => __( 'Change video' ), 'default' => __( 'Default' ), 'remove' => __( 'Remove' ), 'placeholder' => __( 'No video selected' ), 'frame_title' => __( 'Select video' ), 'frame_button' => __( 'Choose video' ), ); case 'audio': return array( 'select' => __( 'Select audio' ), 'change' => __( 'Change audio' ), 'default' => __( 'Default' ), 'remove' => __( 'Remove' ), 'placeholder' => __( 'No audio selected' ), 'frame_title' => __( 'Select audio' ), 'frame_button' => __( 'Choose audio' ), ); case 'image': return array( 'select' => __( 'Select image' ), 'site_icon' => __( 'Select Site Icon' ), 'change' => __( 'Change image' ), 'default' => __( 'Default' ), 'remove' => __( 'Remove' ), 'placeholder' => __( 'No image selected' ), 'frame_title' => __( 'Select image' ), 'frame_button' => __( 'Choose image' ), ); default: return array( 'select' => __( 'Select file' ), 'change' => __( 'Change file' ), 'default' => __( 'Default' ), 'remove' => __( 'Remove' ), 'placeholder' => __( 'No file selected' ), 'frame_title' => __( 'Select file' ), 'frame_button' => __( 'Choose file' ), ); } // End switch(). } } class-wp-customize-cropped-image-control.php000064400000002663152222507600015226 0ustar00json['width'] = absint( $this->width ); $this->json['height'] = absint( $this->height ); $this->json['flex_width'] = absint( $this->flex_width ); $this->json['flex_height'] = absint( $this->flex_height ); } }