=' ) || !version_compare( $wp_version, '3.0', '>=' ) ) { if( IS_ADMIN && ( !defined( 'DOING_AJAX' ) || !DOING_AJAX ) ) { require_once ABSPATH.'/wp-admin/includes/plugin.php'; deactivate_plugins( __FILE__ ); wp_die( __('Attachments requires PHP 5.2 or higher, as does WordPress 3.2+. Attachments has been automatically deactivated.') ); } else { return; } } // ========= // = HOOKS = // ========= if( IS_ADMIN ) { // pre-flight check add_action( 'init', 'attachments_pre_init' ); // get our assets in line add_action( 'admin_enqueue_scripts', 'attachments_enqueues' ); add_action( 'admin_head', 'attachments_init_js' ); // get our menu in line add_action( 'admin_menu', 'attachments_menu' ); // need our textdomain add_action( 'plugins_loaded', 'attachments_localization' ); // make sure we've got our settings in place add_action( 'admin_init', 'attachments_register_settings' ); // make sure we handle the save add_action( 'save_post', 'attachments_save' ); // invoke our meta box add_action( 'add_meta_boxes', 'attachments_meta_box' ); } function attachments_localization() { load_plugin_textdomain( 'attachments', false, ATTACHMENTS_DIR . '/languages/' ); } function attachments_enqueues( $hook ) { wp_enqueue_style( 'attachments', trailingslashit( ATTACHMENTS_URL ) . 'css/attachments.css' ); if( 'edit.php' != $hook && 'post.php' != $hook && 'post-new.php' != $hook ) return; wp_enqueue_script( 'handlebars', trailingslashit( ATTACHMENTS_URL ) . 'js/handlebars.js', null, '1.0.beta.6', false ); wp_enqueue_script( 'attachments', trailingslashit( ATTACHMENTS_URL ) . 'js/attachments.js', array( 'handlebars', 'jquery', 'thickbox' ), ATTACHMENTS_VERSION, true ); wp_enqueue_style( 'thickbox' ); } // ============= // = FUNCTIONS = // ============= function attachments_pre_init() { // as of version 1.6 we'll be storing a proper settings array if( !get_option( ATTACHMENTS_PREFIX . 'settings' ) ) { $settings = array(); // we've got a version < 1.6 and therefore no real settings $settings['version'] = ATTACHMENTS_VERSION; $post_parent = get_option( 'attachments_store_native' ); if( $post_parent === false ) { // it wasn't set $settings['post_parent'] = false; } else { $settings['post_parent'] = true; } // grab our custom post types $args = array( 'public' => true, 'show_ui' => true, '_builtin' => false ); $output = 'objects'; $operator = 'and'; $post_types = get_post_types( $args, $output, $operator ); // we also want to optionally enable Pages and Posts $post_types['post']->labels->name = 'Posts'; $post_types['post']->name = 'post'; $post_types['page']->labels->name = 'Pages'; $post_types['page']->name = 'page'; if( count( $post_types ) ) { foreach( $post_types as $post_type ) { $post_parent = get_option( 'attachments_cpt_' . $post_type->name ); if( $post_parent === false ) { // it wasn't set $settings['post_types'][$post_type->name] = false; } else { $settings['post_types'][$post_type->name] = true; } } } // save our settings update_option( ATTACHMENTS_PREFIX . 'settings', $settings ); } } function attachments_register_settings() { // flag our settings register_setting( ATTACHMENTS_PREFIX . 'settings', ATTACHMENTS_PREFIX . 'settings', 'attachments_validate_settings' ); add_settings_section( ATTACHMENTS_PREFIX . 'options', 'Post Type Settings', 'attachments_edit_options', 'attachments_options' ); // post types add_settings_field( ATTACHMENTS_PREFIX . 'post_types', 'Post Types', 'attachments_edit_post_types', 'attachments_options', ATTACHMENTS_PREFIX . 'options' ); // post_parent add_settings_field( ATTACHMENTS_PREFIX . 'post_parent', 'Set Post Parent', 'attachments_edit_post_parent', 'attachments_options', ATTACHMENTS_PREFIX . 'options' ); } function attachments_edit_options() { } function attachments_validate_settings($input) { $input['version'] = ATTACHMENTS_VERSION; return $input; } function attachments_edit_post_parent() { $settings = get_option( ATTACHMENTS_PREFIX . 'settings' ); ?>
true, 'show_ui' => true, '_builtin' => false ); $output = 'objects'; $operator = 'and'; $post_types = get_post_types( $args, $output, $operator ); // we also want to optionally enable Pages and Posts $post_types['post']->labels->name = 'Posts'; $post_types['post']->name = 'post'; $post_types['page']->labels->name = 'Pages'; $post_types['page']->name = 'page'; if( count( $post_types ) ) : foreach($post_types as $post_type) : ?>
$b ) { return 1; } else { return 0; } } /** * Creates the markup for the WordPress admin options page * * @return void * @author Jonathan Christopher */ function attachments_options() { include 'attachments.options.php'; } /** * Creates the entry for Attachments Options under Settings in the WordPress Admin * * @return void * @author Jonathan Christopher */ function attachments_menu() { add_options_page('Settings', 'Attachments', 'manage_options', __FILE__, 'attachments_options'); } /** * Inserts HTML for meta box, including all existing attachments * * @return void * @author Jonathan Christopher */ function attachments_add() { ?>
  • Drag

    Thumbnail
  • true, 'show_ui' => true ); $output = 'objects'; $operator = 'and'; $post_types = get_post_types( $args, $output, $operator ); foreach($post_types as $post_type) { if( isset( $settings['post_types'][$post_type->name] ) && $settings['post_types'][$post_type->name] ) { add_meta_box( 'attachments_list', __( 'Attachments', 'attachments' ), 'attachments_add', $post_type->name, 'normal' ); } } } } /** * Echos JavaScript that sets some required global variables * * @return void * @author Jonathan Christopher */ function attachments_init_js() { echo ''; } /** * Fired when Post or Page is saved. Serializes all attachment data and saves to post_meta * * @param int $post_id The ID of the current post * @return void * @author Jonathan Christopher * @author JR Tashjian */ function attachments_save($post_id) { // verify this came from the our screen and with proper authorization, // because save_post can be triggered at other times if( !isset( $_POST['attachments_nonce'] ) ) { return $post_id; } if( !wp_verify_nonce( $_POST['attachments_nonce'], plugin_basename(__FILE__) ) ) { return $post_id; } // verify if this is an auto save routine. If it is our form has not been submitted, so we dont want // to do anything if( defined('DOING_AUTOSAVE') && DOING_AUTOSAVE ) { return $post_id; } // Check permissions if( 'page' == $_POST['post_type'] ) { if( !current_user_can( 'edit_page', $post_id ) ) { return $post_id; } } else { if( !current_user_can( 'edit_post', $post_id ) ) { return $post_id; } } // OK, we're authenticated: we need to find and save the data // delete all current attachments meta // moved outside conditional, else we can never delete all attachments delete_post_meta( $post_id, '_attachments' ); // Since we're allowing Attachments to be sortable, we can't simply increment a counter // we need to keep track of the IDs we're given $attachment_ids = array(); // We'll build our array of attachments foreach( $_POST as $key => $data ) { // Arbitrarily using the id if( substr($key, 0, 14) == 'attachment_id_' ) { array_push( $attachment_ids, substr( $key, 14, strlen( $key ) ) ); } } // If we have attachments, there's work to do if( !empty( $attachment_ids ) ) { foreach ( $attachment_ids as $i ) { if( !empty( $_POST['attachment_id_' . $i] ) ) { $attachment_id = intval( $_POST['attachment_id_' . $i] ); $attachment_details = array( 'id' => $attachment_id, 'title' => str_replace( '"', '"', $_POST['attachment_title_' . $i] ), 'caption' => str_replace( '"', '"', $_POST['attachment_caption_' . $i] ), 'order' => intval( $_POST['attachment_order_' . $i] ) ); // serialize data and encode $attachment_serialized = base64_encode( serialize( $attachment_details ) ); // add individual attachment add_post_meta( $post_id, '_attachments', $attachment_serialized ); // save native Attach $settings = get_option( ATTACHMENTS_PREFIX . 'settings' ); if( isset( $settings['post_parent'] ) && $settings['post_parent'] ) { // need to first check to make sure we're not overwriting a native Attach $attach_post_ref = get_post( $attachment_id ); if( $attach_post_ref->post_parent == 0 ) { // no current Attach, we can add ours $attach_post = array(); $attach_post['ID'] = $attachment_id; $attach_post['post_parent'] = $post_id; wp_update_post( $attach_post ); } } } } } } /** * Returns a formatted filesize * * @param string $path Path to file on disk * @return string $formatted formatted filesize * @author Jonathan Christopher */ function attachments_get_filesize_formatted( $path = NULL ) { $formatted = '0 bytes'; if( file_exists( $path ) ) { $formatted = size_format( @filesize( $path ) ); } return $formatted; } /** * Retrieves all Attachments for provided Post or Page * * @param int $post_id (optional) ID of target Post or Page, otherwise pulls from global $post * @return array $post_attachments * @author Jonathan Christopher * @author JR Tashjian */ function attachments_get_attachments( $post_id=null ) { global $post; if( $post_id==null ) { $post_id = $post->ID; } // get all attachments $existing_attachments = get_post_meta( $post_id, '_attachments', false ); // We can now proceed as normal, all legacy data should now be upgraded $post_attachments = array(); if( is_array( $existing_attachments ) && count( $existing_attachments ) > 0 ) { foreach ($existing_attachments as $attachment) { // decode and unserialize the data $data = unserialize( base64_decode( $attachment ) ); array_push( $post_attachments, array( 'id' => stripslashes( $data['id'] ), 'name' => stripslashes( get_the_title( $data['id'] ) ), 'mime' => stripslashes( get_post_mime_type( $data['id'] ) ), 'title' => stripslashes( $data['title'] ), 'caption' => stripslashes( $data['caption'] ), 'filesize' => stripslashes( attachments_get_filesize_formatted( get_attached_file( $data['id'] ) ) ), 'location' => stripslashes( wp_get_attachment_url( $data['id'] ) ), 'order' => stripslashes( $data['order'] ) )); } // sort attachments if( count( $post_attachments ) > 1 ) { usort( $post_attachments, "attachments_cmp" ); } } return $post_attachments; }