class-fl-builder-admin-posts.php 3.9 KB
<?php

/**
 * Handles logic for the post edit screen. 
 *
 * @since 1.0
 */
final class FLBuilderAdminPosts {
	
	/** 
	 * Initialize hooks.
	 *
	 * @since 1.8
	 * @return void
	 */
	static public function init()
	{
		/* Actions */
		add_action('current_screen',                __CLASS__ . '::init_rendering');
		
		/* Filters */
		add_filter('redirect_post_location',        __CLASS__ . '::redirect_post_location');
		add_filter('page_row_actions',              __CLASS__ . '::render_row_actions_link');
		add_filter('post_row_actions',              __CLASS__ . '::render_row_actions_link');
	}
	
	/** 
	 * Sets the body class, loads assets and renders the UI
	 * if we are on a post type that supports the builder.
	 *
	 * @since 1.0
	 * @return void
	 */
	static public function init_rendering()
	{
		global $pagenow;
		
		if ( in_array( $pagenow, array( 'post.php', 'post-new.php') ) ) {
			
			$post_types = FLBuilderModel::get_post_types();
			$screen		= get_current_screen();

			if ( in_array( $screen->post_type, $post_types ) ) {
				add_filter( 'admin_body_class',         __CLASS__ . '::body_class', 99 );
				add_action( 'admin_enqueue_scripts',    __CLASS__ . '::styles_scripts' );
				add_action( 'edit_form_after_title',    __CLASS__ . '::render' );
			}
		}
	}
	 
	/**
	 * Enqueues the CSS/JS for the post edit screen.
	 *
	 * @since 1.0
	 * @return void
	 */	 
	static public function styles_scripts()
	{
		global $wp_version;
		
		// Styles
		wp_enqueue_style( 'fl-builder-admin-posts', FL_BUILDER_URL . 'css/fl-builder-admin-posts.css', array(), FL_BUILDER_VERSION );
		
		// Legacy WP Styles (3.7 and below)
		if ( version_compare( $wp_version, '3.7', '<=' ) ) {
			wp_enqueue_style( 'fl-builder-admin-posts-legacy', FL_BUILDER_URL . 'css/fl-builder-admin-posts-legacy.css', array(), FL_BUILDER_VERSION );
		}
		
		// Scripts
		wp_enqueue_script( 'json2' );
		wp_enqueue_script( 'fl-builder-admin-posts', FL_BUILDER_URL . 'js/fl-builder-admin-posts.js', array(), FL_BUILDER_VERSION );
	}
	 
	/**
	 * Adds classes to the post edit screen body class.
	 *
	 * @since 1.0
	 * @param string $classes The existing body classes.
	 * @return string The body classes.
	 */	 
	static public function body_class( $classes = '' )
	{
		global $wp_version;
		
		// Builder body class
		if ( FLBuilderModel::is_builder_enabled() ) {
			$classes .= ' fl-builder-enabled';
		}
		
		// Pre WP 3.8 body class
		if ( version_compare( $wp_version, '3.8', '<' ) ) {
			$classes .= ' fl-pre-wp-3-8';
		}
		
		return $classes;
	}
	 
	/**
	 * Renders the HTML for the post edit screen.
	 *
	 * @since 1.0
	 * @return void
	 */	 
	static public function render()
	{
		global $post;
		
		$post_type_obj 	= get_post_type_object ( $post->post_type );
		$post_type_name = strtolower( $post_type_obj->labels->singular_name );
		$enabled 		= FLBuilderModel::is_builder_enabled();
		
		include FL_BUILDER_DIR . 'includes/admin-posts.php';
	}
	 
	/**
	 * Renders the action link for post listing pages.
	 *
	 * @since 1.0
	 * @param array $actions
	 * @return array The array of action data.
	 */	 
	static public function render_row_actions_link( $actions = array() ) 
	{
		global $post;
			
		if ( 'trash' != $post->post_status && current_user_can( 'edit_post', $post->ID ) && wp_check_post_lock( $post->ID ) === false ) {
			
			$post_types = FLBuilderModel::get_post_types();

			if ( in_array( $post->post_type, $post_types ) ) {
				$actions['fl-builder'] = '<a href="' . FLBuilderModel::get_edit_url() . '">' . FLBuilderModel::get_branding() . '</a>';
			}
		}
		
		return $actions;
	}
	 
	/**
	 * Where to redirect this post on save.
	 *
	 * @since 1.0
	 * @param string $location
	 * @return string The location to redirect this post on save.
	 */	 
	static public function redirect_post_location( $location ) 
	{
		if ( isset( $_POST['fl-builder-redirect'] ) ) {
			$location = $_POST['fl-builder-redirect'];
		}
		
		return $location;
	}
}

FLBuilderAdminPosts::init();