Je travaille avec une installation fortement personnalisée de WP. J'ai mis en place un type de publication, une taxonomie et des rôles spécifiques qui permettent d'utiliser uniquement ce type de publication.
Idéalement, j'aimerais limiter les membres de ce rôle qui utilisent ce type d'article à ne créer qu'un seul article. Cela semble être plus ennuyeux que ça en vaut la peine. Donc, à part cela, j'aimerais afficher uniquement les plus anciens de leurs messages dans une vue d'archives.
J'ai le texte suivant, qui crée une boucle d'archivage fonctionnelle, mais je n'ai pas encore trouvé le bit "si le nombre de messages> 1 ne montre que le plus ancien message".
$args = array
('post_type' => 'ticketlisting',
'posts_per_page' => 50,
'tax_query' => array
(array
(
'taxonomy' => 'tier',
'field' => 'slug',
'terms' => 'goldstar'
)
)
);
$loop = new WP_Query( $args );
while ( $loop->have_posts() ) : $loop->the_post();
the_title();
echo '<div class="entry-content">';
$post_id = get_the_ID();
/* show post content here */
echo '</div>';
endwhile;
Pour limiter les utilisateurs à un seul message, ne les laissez pas créer de nouveaux messages. Ajoutez simplement une instance wp_editor()
à leur profil.
'show_user_profile'
et 'edit_user_profile'
pour afficher l'éditeur.'personal_options_update'
et 'edit_user_profile_update'
pour enregistrer le contenu dans une méta utilisateur ou un type de publication personnalisé masqué.Maintenant, ils ne doivent plus chercher et ne peuvent pas créer de nouveaux messages.
Pour illustrer ce que je veux dire, j'ai rafraîchi un ancien plugin:
<?php # -*- coding: utf-8 -*-
/**
* Plugin Name: T5 User text rich editor
* Text Domain: t5_utre
* Domain Path: /lang
* Description: Adds a rich editor to the user profile.
* Version: 2012.02.28
* Required: 3.3
* Author: Thomas Scholz <[email protected]>
* Author URI: http://toscho.de
* License: MIT
* License URI: http://www.opensource.org/licenses/mit-license.php
*
* Copyright (c) 2012 Thomas Scholz
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
// Not a WordPress context? Stop.
! defined( 'ABSPATH' ) and exit;
// Back end
add_action( 'admin_init', array ( 'T5_User_Text_Rich_Edit', 'init' ) );
// Front end
// Call it your theme’s author.php:
// do_action( 'print_t5_user_rich_text', $GLOBALS['authordata']->ID );
add_action(
'print_t5_user_rich_text',
array ( 'T5_User_Text_Rich_Edit', 'get_user_rich_text' ),
4
);
class T5_User_Text_Rich_Edit
{
protected
/**
* Internal name for the user meta field.
* @type string
*/
$handle = 'meta_post'
/**
* Current user ID
*
* @type int
*/
, $user_id = NULL
;
/**
* Copy of $handle. Used by the static method.
*
* @type string
*/
protected static $public_handle = 'meta_post';
/**
* Creates a new instance. Called on 'admin_init'.
*
* @see __construct()
* @return void
*/
public static function init()
{
new self;
}
/**
* Contructor. Registers filters and actions.
*
* @param array $params Just 'handle', may be extended.
* @return void
*/
public function __construct( $params = array () )
{
isset ( $params['handle'] )
and $this->handle = $params['handle']
and self::$public_handle = $params['handle'];
add_action( 'show_user_profile', array ( $this, 'show' ) );
add_action( 'edit_user_profile', array ( $this, 'show' ) );
add_action( 'personal_options_update', array ( $this, 'save' ) );
add_action( 'edit_user_profile_update', array ( $this, 'save' ) );
}
/**
* Public access to the field in your theme or plugin.
*
* @param int $user_id
* @param string $before
* @param string $after
* @return string
*/
public static function get_user_rich_text(
$user_id,
$before = '',
$after = '',
$print = TRUE
)
{
$content = get_the_author_meta( self::$public_handle, $user_id );
! empty ( $content )
and $content = $before . wpautop( $content ) . $after;
$print and print $content;
return $content;
}
/**
* Prints the form.
*
* @param object $user
* @return void
*/
public function show( $user )
{
if ( ! current_user_can( 'edit_user', $user->ID ) )
{
return;
}
$label_text = __( 'Your personal post', 't5_utre' );
$label = "<label for='$this->handle'>$label_text</label>";
?>
<table class="form-table">
<tr>
<th>
<?php
print $label;
?>
</th>
<td>
<div style="width:504px">
<?php
$content = get_the_author_meta( $this->handle, $user->ID );
$this->print_editor( $content );
?>
</div>
</td>
</tr>
</table>
<?php
}
/**
* Print a new instance of wp_editor()
*
* @param string $content existing content
* @return void
*/
protected function print_editor( $content )
{
$editor_settings = array (
'textarea_rows' => 15
, 'media_buttons' => TRUE
, 'teeny' => FALSE
, 'tinymce' => TRUE
);
wp_editor( $content, $this->handle, $editor_settings );
}
/**
* Saves the data.
*
* @param int $user_id
* @return void
*/
public function save( $user_id )
{
if ( ! current_user_can( 'edit_user', $user_id ) )
{
return;
}
$this->user_id = $user_id;
$text_input = empty ( $_POST[ $this->handle ] ) ? '' : $_POST[ $this->handle ];
update_user_meta( $user_id, $this->handle, $text_input );
}
}
Vous devez ajouter les fichiers de langue vous-même (ou je les mets sur GitHub si quelqu'un est assez intéressé).
Vous obtenez maintenant un éditeur Nice au bas du profil de l'utilisateur:
Dans le author.php
de votre thème, vous pouvez utiliser l'action prédéfinie pour accéder aux données:
<?php do_action( 'print_t5_user_rich_text', $GLOBALS['authordata']->ID ); ?>
Ce plugin ne touche aucune autre capacité que l'utilisateur pourrait avoir. Il est lié à la possibilité de modifier son propre profil, rien d’autre.