J'ai vu un chemin d'URL pour afficher tous les messages d'un "format" particulier il y a quelques semaines, mais j'ai perdu le lien. Est-ce que quelqu'un connaît le chemin?
Ce sera quelque chose comme
mywebsitex.com/format/image
Fonctionne sur un WP install standard
mywebsitex.com/type/image/
Des idées?
Le format post est une taxonomie par défaut, enregistrée auprès de:
register_taxonomy( 'post_format', 'post', array(
'public' => true,
'hierarchical' => false,
'labels' => array(
'name' => _x( 'Format', 'post format' ),
'singular_name' => _x( 'Format', 'post format' ),
),
'query_var' => true,
'rewrite' => $rewrite['post_format'],
'show_ui' => false,
'_builtin' => true,
'show_in_nav_menus' => current_theme_supports( 'post-formats' ),
) );
où
$rewrite['post_format'] = $post_format_base ? array( 'slug' => $post_format_base ):false;
et
$post_format_base = apply_filters( 'post_format_rewrite_base', 'type' );
Notez que le slug de taxonomie est post_format
et le slug de réécriture est type
.
Nous pouvons voir les formats de publication disponibles à partir de la fonction get_post_format_strings()
:
/**
* Returns an array of post format slugs to their translated and pretty display versions
*
* @since 3.1.0
*
* @return array The array of translated post format names.
*/
function get_post_format_strings() {
$strings = array(
'standard' => _x( 'Standard', 'Post format' ), // Special case. any value that evals to false will be considered standard
'aside' => _x( 'Aside', 'Post format' ),
'chat' => _x( 'Chat', 'Post format' ),
'gallery' => _x( 'Gallery', 'Post format' ),
'link' => _x( 'Link', 'Post format' ),
'image' => _x( 'Image', 'Post format' ),
'quote' => _x( 'Quote', 'Post format' ),
'status' => _x( 'Status', 'Post format' ),
'video' => _x( 'Video', 'Post format' ),
'audio' => _x( 'Audio', 'Post format' ),
);
return $strings;
}
Les termes ont le slug post-format-{$format}
où $format
peut être l'un des suivants:
aside, chat, gallery, link, image, quote, status, video, audio
où standard
n'est pas inclus.
Ici vous pouvez voir les règles de réécriture générées correspondantes:
selon le Monkeyman Rewrite Analyzer .
Nous pouvons donc utiliser les requêtes publiques suivantes:
http://example.tld/type/post-format-aside/
http://example.tld/type/post-format-chat/
http://example.tld/type/post-format-gallery/
http://example.tld/type/post-format-link/
http://example.tld/type/post-format-image/
http://example.tld/type/post-format-quote/
http://example.tld/type/post-format-status/
http://example.tld/type/post-format-video/
http://example.tld/type/post-format-audio/
pour afficher tous les messages dans un format de message donné.
@ToddBenrud a déclaré avoir réussi à obtenir:
http://example.tld/type/image/
travailler.
La raison en est le filtre request
suivant:
/**
* Filters the request to allow for the format prefix.
*
* @access private
* @since 3.1.0
*/
function _post_format_request( $qvs ) {
if ( ! isset( $qvs['post_format'] ) )
return $qvs;
$slugs = get_post_format_slugs();
if ( isset( $slugs[ $qvs['post_format'] ] ) )
$qvs['post_format'] = 'post-format-' . $slugs[ $qvs['post_format'] ];
$tax = get_taxonomy( 'post_format' );
if ( ! is_admin() )
$qvs['post_type'] = $tax->object_type;
return $qvs;
}
add_filter( 'request', '_post_format_request' );
Cela signifie qu'une demande avec la variable de requête:
Array
(
[post_format] => image
)
est modifié pour le nom de terme correct:
Array
(
[post_format] => post-format-image
[post_type] => Array
(
[0] => post
)
)
Nous pourrions donc aussi utiliser:
http://example.tld/type/aside/
http://example.tld/type/chat/
http://example.tld/type/gallery/
http://example.tld/type/link/
http://example.tld/type/image/
http://example.tld/type/quote/
http://example.tld/type/status/
http://example.tld/type/video/
http://example.tld/type/audio/