Support » Plugin: BuddyPress Docs » Clone a doc and assign to a different group

  • timelessco

    (@timelessco)


    Hi,
    I’m trying to basically have buddypress doc *templates* that I can clone when a new bp group is created and assign to them.

    I’m cloning the doc like I would any other post type and it’s working, but I can’t figure out how to change the association to a BP group.

    function rd_duplicate_post_as_draft( $user_data, $post_ids, $order_id ){
    	// global $wpdb;
    	// if (! ( isset( $_GET['post']) || isset( $_POST['post'])  || ( isset($_REQUEST['action']) && 'rd_duplicate_post_as_draft' == $_REQUEST['action'] ) ) ) {
    	// 	wp_die('No post to duplicate has been supplied!');
    	// }
     
    	/*
    	 * Nonce verification
    	 */
    	// if ( !isset( $_GET['duplicate_nonce'] ) || !wp_verify_nonce( $_GET['duplicate_nonce'], basename( __FILE__ ) ) )
    	// 	return;
     
    	/*
    	 * get the original post id
    	 */
    	$post_id = 12210;
    	/*
    	 * and all the original post data then
    	 */
    	$post = get_post( $post_id );
     
    	/*
    	 * if you don't want current user to be the new post author,
    	 * then change next couple of lines to this: $new_post_author = $post->post_author;
    	 */
    	// $current_user = wp_get_current_user();
    	$user = get_user_by( 'email', $user_data['user_email'] );
    	$new_post_author = $user_data['user_id'] = $user->ID;
     
    	/*
    	 * if post data exists, create the post duplicate
    	 */
    	if (isset( $post ) && $post != null) {
     
    		/*
    		 * new post data array
    		 */
    		$args = array(
    			'comment_status' => $post->comment_status,
    			'ping_status'    => $post->ping_status,
    			'post_author'    => $new_post_author,
    			'post_content'   => $post->post_content,
    			'post_excerpt'   => $post->post_excerpt,
    			'post_name'      => $post->post_name,
    			'post_parent'    => $post->post_parent,
    			'post_password'  => $post->post_password,
    			'post_status'    => $post->post_status,
    			'post_title'     => $post->post_title,
    			'post_type'      => $post->post_type,
    			'to_ping'        => $post->to_ping,
    			'menu_order'     => $post->menu_order,
    			'group_id'       => learndash_get_users_group_ids($new_post_author)
    		);
     
    		/*
    		 * insert the post by wp_insert_post() function
    		 */
    		$new_post_id = wp_insert_post( $args );
     
    		/*
    		 * get all current post terms ad set them to the new post draft
    		 */
    		$taxonomies = get_object_taxonomies($post->post_type); // returns array of taxonomy names for post type, ex array("category", "post_tag");
    		foreach ($taxonomies as $taxonomy) {
    			$post_terms = wp_get_object_terms($post_id, $taxonomy, array('fields' => 'slugs'));
    			wp_set_object_terms($new_post_id, $post_terms, $taxonomy, false);
    		}
     
    		/*
    		 * duplicate all post meta just in two SQL queries
    		 */
    		$post_meta_infos = $wpdb->get_results("SELECT meta_key, meta_value FROM $wpdb->postmeta WHERE post_id=$post_id");
    		if (count($post_meta_infos)!=0) {
    			$sql_query = "INSERT INTO $wpdb->postmeta (post_id, meta_key, meta_value) ";
    			foreach ($post_meta_infos as $meta_info) {
    				$meta_key = $meta_info->meta_key;
    				if( $meta_key == '_wp_old_slug' ) continue;
    				$meta_value = addslashes($meta_info->meta_value);
    				$sql_query_sel[]= "SELECT $new_post_id, '$meta_key', '$meta_value'";
    			}
    			$sql_query.= implode(" UNION ALL ", $sql_query_sel);
    			$wpdb->query($sql_query);
    		}
     
     
    		/*
    		 * finally, redirect to the edit post screen for the new draft
    		 */
    		// wp_redirect( admin_url( 'post.php?action=edit&post=' . $new_post_id ) );
    		exit;
    	} else {
    		wp_die('Post creation failed, could not find original post: ' . $post_id);
    	}
    }
    add_action( 'ulgm_group_leader_added', 'rd_duplicate_post_as_draft', 10, 3);
    // do_action('ulgm_group_leader_added', $user_data, $post_ids, $order_id );
    ?>
    

    Any help is much appreciated, thanks!

    • This topic was modified 1 year ago by timelessco.
Viewing 1 replies (of 1 total)
Viewing 1 replies (of 1 total)
  • The topic ‘Clone a doc and assign to a different group’ is closed to new replies.