最新消息:Welcome to the puzzle paradise for programmers! Here, a well-designed puzzle awaits you. From code logic puzzles to algorithmic challenges, each level is closely centered on the programmer's expertise and skills. Whether you're a novice programmer or an experienced tech guru, you'll find your own challenges on this site. In the process of solving puzzles, you can not only exercise your thinking skills, but also deepen your understanding and application of programming knowledge. Come to start this puzzle journey full of wisdom and challenges, with many programmers to compete with each other and show your programming wisdom! Translated with DeepL.com (free version)

plugins - Woocommerce: limit user to see only the products he created

matteradmin7PV0评论

I have this code where the authors can see only own posts. I need the authors to see only the products they have created on woocommerce. I know the woocommerce products have no authors by default, but I can add this with a plugin. Whats I want to do is to change this snippet to limit the lists of products in the custom post type of woocommerce.

Someone know the best way to do that?

Thanks!

function posts_for_current_author($query) {
        global $pagenow;

    if( 'edit.php' != $pagenow || !$query->is_admin )
        return $query;

    if( !current_user_can( 'manage_options' ) ) {
       global $user_ID;
       $query->set('author', $user_ID );
     }
     return $query;
}
add_filter('pre_get_posts', 'posts_for_current_author');

I have this code where the authors can see only own posts. I need the authors to see only the products they have created on woocommerce. I know the woocommerce products have no authors by default, but I can add this with a plugin. Whats I want to do is to change this snippet to limit the lists of products in the custom post type of woocommerce.

Someone know the best way to do that?

Thanks!

function posts_for_current_author($query) {
        global $pagenow;

    if( 'edit.php' != $pagenow || !$query->is_admin )
        return $query;

    if( !current_user_can( 'manage_options' ) ) {
       global $user_ID;
       $query->set('author', $user_ID );
     }
     return $query;
}
add_filter('pre_get_posts', 'posts_for_current_author');
Share Improve this question asked Mar 20, 2019 at 20:21 Fernando AurelianoFernando Aureliano 1032 bronze badges 0
Add a comment  | 

1 Answer 1

Reset to default 1

I believe changing the following conditional:

if( !current_user_can( 'manage_options' ) )

to this one:

if( !current_user_can( 'manage_options' ) && 'product' === $query->get( 'post_type' ) )

would do it.

Brief explanation: I added a second condition which checks if the query is for WooCommerce products where the post type is product.

UPDATE

If you want to make certain that the code runs only on the products page (WooCommerce → Products), then you can (remove the global $pagenow; and) change this:

if( 'edit.php' != $pagenow || !$query->is_admin )

to this one:

if( !$query->is_admin || 'edit-product' !== get_current_screen()->id )

And instead of relying on the global $user_ID, you should probably use get_current_user_id(): $query->set( 'author', get_current_user_id() ); :)

Post a comment

comment list (0)

  1. No comments so far