PK œqhYî¶J‚ßF ßF ) nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/
Dir : /home/trave494/demostore1.kerihosting.com/df/f/wp-content/themes/genesis/lib/admin/ |
Server: Linux ngx353.inmotionhosting.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64 IP: 209.182.202.254 |
Dir : //home/trave494/demostore1.kerihosting.com/df/f/wp-content/themes/genesis/lib/admin/term-meta.php |
<?php /** * Genesis Framework. * * WARNING: This file is part of the core Genesis Framework. DO NOT edit this file under any circumstances. * Please do all modifications in the form of a child theme. * * @package Genesis\Admin * @author StudioPress * @license GPL-2.0-or-later * @link https://my.studiopress.com/themes/genesis/ */ /** * Term meta defaults. * * @since 2.2.6 * * @return array Default term meta values. */ function genesis_term_meta_defaults() { return apply_filters( 'genesis_term_meta_defaults', array( 'headline' => '', 'intro_text' => '', 'display_title' => 0, // Vestigial. 'display_description' => 0, // Vestigial. 'doctitle' => '', 'description' => '', 'keywords' => '', 'layout' => '', 'noindex' => 0, 'nofollow' => 0, 'noarchive' => 0, ) ); } add_action( 'admin_init', 'genesis_add_taxonomy_archive_options' ); /** * Add the archive options to each custom taxonomy edit screen. * * @since 1.6.0 * * @see genesis_taxonomy_archive_options() Callback for headline and introduction fields. */ function genesis_add_taxonomy_archive_options() { foreach ( get_taxonomies( array( 'public' => true, ) ) as $tax_name ) { add_action( $tax_name . '_edit_form', 'genesis_taxonomy_archive_options', 10, 2 ); } } /** * Echo headline and introduction fields on the taxonomy term edit form. * * If populated, the values saved in these fields may display on taxonomy archives. * * @since 1.6.0 * * @see genesis_add_taxonomy_archive_options() Callback caller. * * @param \stdClass $tag Term object. * @param string $taxonomy Name of the taxonomy. */ function genesis_taxonomy_archive_options( $tag, $taxonomy ) { genesis_meta_boxes()->show_meta_box( 'genesis-term-meta-settings', $tag ); } add_action( 'admin_init', 'genesis_add_taxonomy_seo_options' ); /** * Add the SEO options to each custom taxonomy edit screen. * * @since 1.3.0 * * @see genesis_taxonomy_seo_options() Callback for SEO fields. */ function genesis_add_taxonomy_seo_options() { foreach ( get_taxonomies( array( 'public' => true, ) ) as $tax_name ) { add_action( $tax_name . '_edit_form', 'genesis_taxonomy_seo_options', 10, 2 ); } } /** * Echo title, description, keywords and robots meta SEO fields on the taxonomy term edit form. * * If populated, the values saved in these fields may be used on taxonomy archives. * * @since 1.2.0 * * @see genesis_add-taxonomy_seo_options() Callback caller. * * @param \stdClass $tag Term object. * @param string $taxonomy Name of the taxonomy. */ function genesis_taxonomy_seo_options( $tag, $taxonomy ) { genesis_meta_boxes()->show_meta_box( 'genesis-term-meta-seo', $tag ); } add_action( 'admin_init', 'genesis_add_taxonomy_layout_options' ); /** * Add the layout options to each custom taxonomy edit screen. * * @since 1.4.0 * * @see genesis_taxonomy_layout_options() Callback for layout selector. */ function genesis_add_taxonomy_layout_options() { if ( ! current_theme_supports( 'genesis-archive-layouts' ) ) { return; } if ( ! genesis_has_multiple_layouts() ) { return; } foreach ( get_taxonomies( array( 'public' => true, ) ) as $tax_name ) { add_action( $tax_name . '_edit_form', 'genesis_taxonomy_layout_options', 10, 2 ); } } /** * Echo the layout options on the taxonomy term edit form. * * @since 1.4.0 * * @see genesis_add_taxonomy_layout_options() Callback caller. * * @param \stdClass $tag Term object. * @param string $taxonomy Name of the taxonomy. */ function genesis_taxonomy_layout_options( $tag, $taxonomy ) { genesis_meta_boxes()->show_meta_box( 'genesis-term-meta-layout', $tag ); } add_filter( 'get_term', 'genesis_get_term_filter', 10, 2 ); /** * For backward compatibility only. * * Sets $term->meta to empty array. All calls to $term->meta->key will be unset unless force set by `genesis_term_meta` filter. * * @since 1.2.0 * * @param object $term Database row object. * @param string $taxonomy Taxonomy name that $term is part of. * @return object Database row object. */ function genesis_get_term_filter( $term, $taxonomy ) { // Do nothing, if $term is not object. if ( ! is_object( $term ) ) { return $term; } // Do nothing, if called in the context of creating a term via an ajax call. if ( did_action( 'wp_ajax_add-tag' ) ) { return $term; } // Still set $term->meta and apply filter, for backward compatibility. $term->meta = apply_filters( 'genesis_term_meta', array(), $term, $taxonomy ); return $term; } add_filter( 'get_terms', 'genesis_get_terms_filter', 10, 2 ); /** * Add Genesis term-meta data to functions that return multiple terms. * * @since 2.0.0 * * @param array $terms Database row objects. * @param string $taxonomy Taxonomy name that $terms are part of. * @return array Database row objects. */ function genesis_get_terms_filter( array $terms, $taxonomy ) { foreach ( $terms as $key => $term ) { $terms[ $key ] = genesis_get_term_filter( $term, $taxonomy ); } return $terms; } add_filter( 'get_term_metadata', 'genesis_term_meta_filter', 10, 4 ); /** * Maintain backward compatibility with the older `genesis_term_meta_{$key}` filter so old filter functions will still work. * * @since 2.3.0 * * @param string|array $value The term meta value. * @param int $object_id The term ID. * @param string $meta_key Meta key. * @param bool $single Whether to return only the first value of the specified $meta_key. * @return mixed Filtered term meta value. */ function genesis_term_meta_filter( $value, $object_id, $meta_key, $single ) { return apply_filters( "genesis_term_meta_{$meta_key}", $value, get_term_field( 'slug', $object_id ), null ); } add_action( 'edit_term', 'genesis_term_meta_save', 10, 2 ); /** * Save term meta data. * * Fires when a user edits and saves a term. * * @since 1.2.0 * * @param int $term_id Term ID. * @param int $tt_id Term Taxonomy ID. */ function genesis_term_meta_save( $term_id, $tt_id ) { if ( defined( 'DOING_AJAX' ) && DOING_AJAX ) { return; } $values = isset( $_POST['genesis-meta'] ) ? (array) $_POST['genesis-meta'] : array(); $values = wp_parse_args( $values, genesis_term_meta_defaults() ); if ( isset( $values['archive_description'] ) && ! current_user_can( 'unfiltered_html' ) ) { $values['archive_description'] = genesis_formatting_kses( $values['archive_description'] ); } foreach ( $values as $key => $value ) { update_term_meta( $term_id, $key, $value ); } } add_action( 'delete_term', 'genesis_term_meta_delete', 10, 2 ); /** * Delete term meta data. * * Fires when a user deletes a term. * * @since 1.2.0 * * @param int $term_id Term ID. * @param int $tt_id Taxonomy Term ID. */ function genesis_term_meta_delete( $term_id, $tt_id ) { foreach ( genesis_term_meta_defaults() as $key => $value ) { delete_term_meta( $term_id, $key ); } } add_action( 'split_shared_term', 'genesis_split_shared_term' ); /** * Create new term meta record for split terms. * * When WordPress splits terms, ensure that the term meta gets preserved for the newly created term. * * @since 2.2.0 * * @param int $old_term_id The ID of the term being split. * @param int $new_term_id The ID of the newly created term. */ function genesis_split_shared_term( $old_term_id, $new_term_id ) { $term_meta = (array) get_option( 'genesis-term-meta' ); if ( ! isset( $term_meta[ $old_term_id ] ) ) { return; } $term_meta[ $new_term_id ] = $term_meta[ $old_term_id ]; update_option( 'genesis-term-meta', $term_meta ); }