-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Graziano Vincini <[email protected]>
- Loading branch information
Showing
3 changed files
with
368 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,194 @@ | ||
<?php | ||
|
||
/** | ||
* USAGE: | ||
* <?php $imgURL = get_cupp_meta( $user_id, $size ); ?> | ||
* or | ||
* <img src="<?php echo get_cupp_meta( $user_id, $size ); ?>"> | ||
* | ||
*/ | ||
|
||
|
||
// Enqueue scripts and styles | ||
add_action( 'admin_enqueue_scripts', 'cupp_enqueue_scripts_styles' ); | ||
function cupp_enqueue_scripts_styles() { | ||
// Register | ||
wp_register_style( 'cupp_admin_css', AERIA_RESOURCE_URL.'/css/userprofilephoto.css', false, '1.0.0', 'all' ); | ||
wp_register_script( 'cupp_admin_js', AERIA_RESOURCE_URL.'/js/userprofilephoto.js', array('jquery'), '1.0.0', true ); | ||
|
||
// Enqueue | ||
wp_enqueue_style( 'cupp_admin_css' ); | ||
wp_enqueue_script( 'cupp_admin_js' ); | ||
} | ||
|
||
// Show the new image field in the user profile page. | ||
add_action( 'show_user_profile', 'cupp_profile_img_fields' ); | ||
add_action( 'edit_user_profile', 'cupp_profile_img_fields' ); | ||
|
||
function cupp_profile_img_fields( $user ) { | ||
if(!current_user_can('upload_files')) | ||
return false; | ||
|
||
// vars | ||
$cupp_url = get_the_author_meta( 'cupp_meta', $user->ID ); | ||
$cupp_upload_url = get_the_author_meta( 'cupp_upload_meta', $user->ID ); | ||
$cupp_upload_edit_url = get_the_author_meta( 'cupp_upload_edit_meta', $user->ID ); | ||
|
||
if(!$cupp_upload_url){ | ||
$btn_text = 'Upload New Image'; | ||
} else { | ||
$cupp_upload_edit_url = get_home_url().get_the_author_meta( 'cupp_upload_edit_meta', $user->ID ); | ||
$btn_text = 'Change Current Image'; | ||
} | ||
?> | ||
|
||
<div id="cupp_container"> | ||
<h3><?php _e( 'Custom User Profile Photo', 'aeria' ); ?></h3> | ||
|
||
<table class="form-table"> | ||
|
||
<tr> | ||
<th><label for="cupp_meta"><?php _e( 'Profile Photo', 'aeria' ); ?></label></th> | ||
<td> | ||
<!-- Outputs the image after save --> | ||
<div id="current_img"> | ||
<?php if($cupp_upload_url): ?> | ||
<img src="<?php echo esc_url( $cupp_upload_url ); ?>" class="cupp-current-img"> | ||
<div class="edit_options uploaded"> | ||
<a class="remove_img"><span>Remove</span></a> | ||
<a href="<?php echo $cupp_upload_edit_url; ?>" class="edit_img" target="_blank"><span>Edit</span></a> | ||
</div> | ||
<?php elseif($cupp_url) : ?> | ||
<img src="<?php echo esc_url( $cupp_url ); ?>" class="cupp-current-img"> | ||
<div class="edit_options single"> | ||
<a class="remove_img"><span>Remove</span></a> | ||
</div> | ||
<?php endif; ?> | ||
</div> | ||
|
||
<!-- Select an option: Upload to WPMU or External URL --> | ||
<div id="cupp_options"> | ||
<input type="radio" id="upload_option" name="img_option" value="upload" class="tog" checked> | ||
<label for="upload_option">Upload New Image</label><br> | ||
<input type="radio" id="external_option" name="img_option" value="external" class="tog"> | ||
<label for="external_option">Use External URL</label><br> | ||
</div> | ||
|
||
<!-- Hold the value here if this is a WPMU image --> | ||
<div id="cupp_upload"> | ||
<input type="hidden" name="cupp_upload_meta" id="cupp_upload_meta" value="<?php echo esc_url_raw( $cupp_upload_url ); ?>" class="hidden" /> | ||
<input type="hidden" name="cupp_upload_edit_meta" id="cupp_upload_edit_meta" value="<?php echo esc_url_raw( $cupp_upload_edit_url ); ?>" class="hidden" /> | ||
<input type='button' class="cupp_wpmu_button button-primary" value="<?php _e( $btn_text, 'aeria' ); ?>" id="uploadimage"/><br /> | ||
</div> | ||
|
||
<!-- Outputs the text field and displays the URL of the image retrieved by the media uploader --> | ||
<div id="cupp_external"> | ||
<input type="text" name="cupp_meta" id="cupp_meta" value="<?php echo esc_url_raw( $cupp_url ); ?>" class="regular-text" /> | ||
</div> | ||
|
||
<!-- Outputs the save button --> | ||
<span class="description"><?php _e( 'Upload a custom photo for your user profile or use a URL to a pre-existing photo.', 'aeria' ); ?></span> | ||
<p class="description"><?php _e('Update Profile to save your changes.', 'aeria'); ?></p> | ||
</td> | ||
</tr> | ||
|
||
</table><!-- end form-table --> | ||
</div> <!-- end #cupp_container --> | ||
|
||
<?php wp_enqueue_media(); // Enqueue the WordPress MEdia Uploader ?> | ||
|
||
<?php } | ||
|
||
// Save the new user CUPP url. | ||
add_action( 'personal_options_update', 'cupp_save_img_meta' ); | ||
add_action( 'edit_user_profile_update', 'cupp_save_img_meta' ); | ||
|
||
function cupp_save_img_meta( $user_id ) { | ||
|
||
if ( !current_user_can( 'edit_user', $user_id ) ) | ||
return false; | ||
|
||
// If the current user can edit Users, allow this. | ||
update_user_meta( $user_id, 'cupp_meta', $_POST['cupp_meta'] ); | ||
update_user_meta( $user_id, 'cupp_upload_meta', $_POST['cupp_upload_meta'] ); | ||
update_user_meta( $user_id, 'cupp_upload_edit_meta', $_POST['cupp_upload_edit_meta'] ); | ||
} | ||
|
||
/** | ||
* Return an ID of an attachment by searching the database with the file URL. | ||
* | ||
* First checks to see if the $url is pointing to a file that exists in | ||
* the wp-content directory. If so, then we search the database for a | ||
* partial match consisting of the remaining path AFTER the wp-content | ||
* directory. Finally, if a match is found the attachment ID will be | ||
* returned. | ||
* | ||
* http://frankiejarrett.com/get-an-attachment-id-by-url-in-wordpress/ | ||
* | ||
* @return {int} $attachment | ||
*/ | ||
function get_attachment_image_by_url( $url ) { | ||
|
||
// Split the $url into two parts with the wp-content directory as the separator. | ||
$parse_url = explode( parse_url( WP_CONTENT_URL, PHP_URL_PATH ), $url ); | ||
|
||
// Get the host of the current site and the host of the $url, ignoring www. | ||
$this_host = str_ireplace( 'www.', '', parse_url( home_url(), PHP_URL_HOST ) ); | ||
$file_host = str_ireplace( 'www.', '', parse_url( $url, PHP_URL_HOST ) ); | ||
|
||
// Return nothing if there aren't any $url parts or if the current host and $url host do not match. | ||
if ( !isset( $parse_url[1] ) || empty( $parse_url[1] ) || ( $this_host != $file_host ) ) { | ||
return; | ||
} | ||
|
||
// Now we're going to quickly search the DB for any attachment GUID with a partial path match. | ||
// Example: /uploads/2013/05/test-image.jpg | ||
global $wpdb; | ||
|
||
$prefix = $wpdb->prefix; | ||
$attachment = $wpdb->get_col( $wpdb->prepare( "SELECT ID FROM " . $prefix . "posts WHERE guid RLIKE %s;", $parse_url[1] ) ); | ||
|
||
// Returns null if no attachment is found. | ||
return $attachment[0]; | ||
} | ||
|
||
/** | ||
* Retrieve the appropriate image size | ||
* | ||
* @param $user_id Default: $post->post_author. Will accept any valid user ID passed into this parameter. | ||
* @param $size Default: 'thumbnail'. Accepts all default WordPress sizes and any custom sizes made by the add_image_size() function. | ||
* @return {url} Use this inside the src attribute of an image tag or where you need to call the image url. | ||
*/ | ||
function get_cupp_meta( $user_id, $size ) { | ||
|
||
//allow the user to specify the image size | ||
if (!$size){ | ||
$size = 'thumbnail'; // Default image size if not specified. | ||
} | ||
if(!$user_id){ | ||
$user_id = $post->post_author; | ||
} | ||
|
||
// get the custom uploaded image | ||
$attachment_upload_url = esc_url( get_the_author_meta( 'cupp_upload_meta', $user_id ) ); | ||
|
||
// get the external image | ||
$attachment_ext_url = esc_url( get_the_author_meta( 'cupp_meta', $user_id ) ); | ||
$attachment_url = ''; | ||
if($attachment_upload_url){ | ||
$attachment_url = $attachment_upload_url; | ||
} elseif($attachment_ext_url) { | ||
$attachment_url = $attachment_ext_url; | ||
} | ||
|
||
// grabs the id from the URL using Frankie Jarretts function | ||
$attachment_id = get_attachment_image_by_url( $attachment_url ); | ||
|
||
// retrieve the thumbnail size of our image | ||
$image_thumb = wp_get_attachment_image_src( $attachment_id, $size ); | ||
|
||
// return the image thumbnail | ||
return $image_thumb[0]; | ||
} | ||
|
||
?> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,103 @@ | ||
/* | ||
Title: 3five Admin CUPP Styles | ||
Author: Vincent Listrani | ||
Description: Styles for WP Admin user page. | ||
*/ | ||
#cupp_container* { | ||
-webkit-box-sizing: border-box; | ||
-moz-box-sizing: border-box; | ||
box-sizing: border-box; | ||
} | ||
|
||
#cupp_container{ | ||
background: #fcfcfc; | ||
padding: 10px; | ||
margin-top: 20px; | ||
} | ||
|
||
/* Current Profile Image Styles */ | ||
#current_img{ | ||
position: relative; | ||
width: 160px; | ||
height: auto; | ||
text-align: right; | ||
margin-bottom: 10px; | ||
} | ||
|
||
.cupp-current-img{ | ||
display: block; | ||
max-width: 150px; | ||
max-height: 150px; | ||
width: 100%; | ||
height: auto; | ||
padding: 4px; | ||
background: #fefefe; | ||
border: 1px solid #e5e5e5; | ||
} | ||
|
||
.edit_options{ | ||
display: block; | ||
-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"; | ||
filter: alpha(opacity=0); | ||
opacity: 0; | ||
position: absolute; | ||
top: 0; | ||
left: 0; | ||
max-width: 160px; | ||
width: 100%; | ||
height: 100%; | ||
background-color: #fff; | ||
background-color: rgba(255, 255, 255, 0.25); | ||
} | ||
.edit_options .remove_img, .edit_options .edit_img{ | ||
float: left; | ||
position: relative; | ||
color: #444; | ||
font-size: 13px; | ||
width: 50%; | ||
height: 100%; | ||
text-align: center; | ||
cursor: pointer; | ||
text-decoration: none; | ||
} | ||
.edit_options span{ | ||
display: block; | ||
position: relative; | ||
top: 50%; | ||
margin-top: -10px; | ||
} | ||
|
||
.edit_options .remove_img{ | ||
color: #fff; | ||
background-color: rgb(214, 14, 14); | ||
background-color: rgba(214, 14, 14, 0.50); | ||
} | ||
|
||
.edit_options.single .remove_img{ | ||
width: 100%; | ||
} | ||
|
||
.edit_options .remove_img:hover, .edit_options .remove_img:focus{ | ||
background-color: #ff0000; | ||
background-color: rgba(214, 14, 14, 0.75); | ||
} | ||
|
||
.edit_options .edit_img{ | ||
color: #fff; | ||
background-color: rgb(50, 50, 50); | ||
background-color: rgba(50, 50, 50, 0.50); | ||
} | ||
|
||
.edit_options .edit_img:hover, .edit_options .edit_img:focus{ | ||
background-color: rgb(25, 25, 25); | ||
background-color: rgba(50, 50, 50, 0.75); | ||
} | ||
|
||
/* Radio Button Styles */ | ||
#cupp_options{ | ||
margin-bottom: 10px; | ||
} | ||
|
||
#cupp_external{ | ||
display: none; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
/* | ||
* Adapted from: http://mikejolley.com/2012/12/using-the-new-wordpress-3-5-media-uploader-in-plugins/ | ||
* Further modified from PippinsPlugins https://gist.github.com/pippinsplugins/29bebb740e09e395dc06 | ||
*/ | ||
jQuery(document).ready(function($){ | ||
// Uploading files | ||
var file_frame; | ||
|
||
jQuery('.cupp_wpmu_button').on('click', function( event ){ | ||
|
||
event.preventDefault(); | ||
|
||
// If the media frame already exists, reopen it. | ||
if ( file_frame ) { | ||
file_frame.open(); | ||
return; | ||
} | ||
|
||
// Create the media frame. | ||
file_frame = wp.media.frames.file_frame = wp.media({ | ||
title: jQuery( this ).data( 'uploader_title' ), | ||
button: { | ||
text: jQuery( this ).data( 'uploader_button_text' ), | ||
}, | ||
multiple: false // Set to true to allow multiple files to be selected | ||
}); | ||
|
||
// When an image is selected, run a callback. | ||
file_frame.on( 'select', function() { | ||
// We set multiple to false so only get one image from the uploader | ||
attachment = file_frame.state().get('selection').first().toJSON(); | ||
|
||
// Do something with attachment.id and/or attachment.url here | ||
// write the selected image url to the value of the #cupp_meta text field | ||
jQuery('#cupp_meta').val(''); | ||
jQuery('#cupp_upload_meta').val(attachment.url); | ||
jQuery('#cupp_upload_edit_meta').val('/wp/wp-admin/post.php?post='+attachment.id+'&action=edit&image-editor'); | ||
jQuery('.cupp-current-img').attr('src', attachment.url); | ||
}); | ||
|
||
// Finally, open the modal | ||
file_frame.open(); | ||
}); | ||
|
||
// Toggle Image Type | ||
jQuery('input[name=img_option]').on('click', function( event ){ | ||
var imgOption = jQuery(this).val(); | ||
|
||
if (imgOption == 'external'){ | ||
jQuery('#cupp_upload').hide(); | ||
jQuery('#cupp_external').show(); | ||
} else if (imgOption == 'upload'){ | ||
jQuery('#cupp_external').hide(); | ||
jQuery('#cupp_upload').show(); | ||
} | ||
|
||
}); | ||
|
||
// Remove Image Function | ||
jQuery('.edit_options').hover(function(){ | ||
jQuery(this).stop(true, true).animate({opacity: 1}, 100); | ||
}, function(){ | ||
jQuery(this).stop(true, true).animate({opacity: 0}, 100); | ||
}); | ||
|
||
jQuery('.remove_img').on('click', function( event ){ | ||
jQuery(this).parent().add('.cupp-current-img').fadeOut('fast', function(){jQuery(this).remove()}); | ||
jQuery('#cupp_upload_meta, #cupp_upload_edit_meta, #cupp_meta').val(''); | ||
}); | ||
|
||
}); |