Trying to get property of non-object in shortocde

You need to call global $post before using $post->ID, or better, use get_the_ID() instead.