work on comic image ordering and zooming

This commit is contained in:
John Bintz 2009-11-03 07:55:08 -05:00
parent e8c2bdabe5
commit f578f1c49e
4 changed files with 115 additions and 22 deletions

View File

@ -12,7 +12,7 @@ class ComicPressAddonCore extends ComicPressAddon {
function init() { function init() {
$this->comicpress = &ComicPress::get_instance(); $this->comicpress = &ComicPress::get_instance();
add_action('admin_menu', array(&$this, 'setup_admin_interface')); add_action('admin_menu', array(&$this, 'admin_menu'));
add_filter('attachment_fields_to_edit', array(&$this, 'setup_comic_metadata_buttons'), 10, 2); add_filter('attachment_fields_to_edit', array(&$this, 'setup_comic_metadata_buttons'), 10, 2);
add_action('show_comic', array(&$this, 'show_comic'), 1, 1); add_action('show_comic', array(&$this, 'show_comic'), 1, 1);
add_action('show_archive', array(&$this, 'show_archive'), 1, 1); add_action('show_archive', array(&$this, 'show_archive'), 1, 1);
@ -191,15 +191,17 @@ class ComicPressAddonCore extends ComicPressAddon {
/** /**
* Set up the admin interface and meta boxes. * Set up the admin interface and meta boxes.
*/ */
function setup_admin_interface() { function admin_menu() {
global $plugin_page, $pagenow, $post; global $plugin_page, $pagenow, $post;
add_theme_page(__("ComicPress Core", 'comicpress'), __('ComicPress Core', 'comicpress'), 'edit_themes', 'comicpress/render_admin', array(&$this, 'render_admin')); add_theme_page(__("ComicPress Core", 'comicpress'), __('ComicPress Core', 'comicpress'), 'edit_themes', 'comicpress/render_admin', array(&$this, 'render_admin'));
add_theme_page(__("Edit Partials", 'comicpress'), __('Edit Partials', 'comicpress'), 'edit_themes', 'comicpress/edit_partials', array(&$this, 'render_edit_partials')); add_theme_page(__("Edit Partials", 'comicpress'), __('Edit Partials', 'comicpress'), 'edit_themes', 'comicpress/edit_partials', array(&$this, 'render_edit_partials'));
if (strpos($page, "edit") === 0) { if (strpos($pagenow, "post") === 0) {
var_dump($post);
add_meta_box("comic-image-ordering", __("Comic Image Ordering", 'comicpress'), array(&$this, 'render_comic_image_ordering'), "post", "normal", "low"); add_meta_box("comic-image-ordering", __("Comic Image Ordering", 'comicpress'), array(&$this, 'render_comic_image_ordering'), "post", "normal", "low");
wp_enqueue_script('cp-ordering', get_stylesheet_directory_uri() . '/js/ComicImageOrdering.js', array('scriptaculous-slider'));
wp_enqueue_style('cp-admin', get_stylesheet_directory_uri() . '/css/cp-admin.css');
add_action('admin_footer', array(&$this, 'admin_footer'));
} }
if ($plugin_page == 'comicpress/render_admin') { if ($plugin_page == 'comicpress/render_admin') {
@ -212,6 +214,16 @@ class ComicPressAddonCore extends ComicPressAddon {
} }
} }
function admin_footer() {
$nonce = wp_create_nonce('comicpress');
?><script type="text/javascript">
var ComicPressAdmin = {
nonce: '<?php echo $nonce ?>',
ajax_uri: '<?php echo trailingslashit(get_bloginfo('url')) ?>'
}
</script>
<?php }
/** /**
* Show comic media. * Show comic media.
* @param object $override_post If not nul;, the post to use instead of the current Loop post. * @param object $override_post If not nul;, the post to use instead of the current Loop post.
@ -337,20 +349,24 @@ class ComicPressAddonCore extends ComicPressAddon {
*/ */
function render_comic_image_ordering() { function render_comic_image_ordering() {
if (isset($_REQUEST['post'])) { if (isset($_REQUEST['post'])) {
$comic_post = new ComicPressComicPost(get_post($_REQUEST['post']), &$this->comicpress); $comic_post = new ComicPressComicPost(get_post($_REQUEST['post']));
$ordering = $comic_post->normalize_comic_image_ordering(); $ordering = $comic_post->normalize_comic_image_ordering();
echo '<input type="hidden" name="cp[_nonce]" value="' . wp_create_nonce('comicpress') . '" />';
if (is_array($ordering)) { if (is_array($ordering)) {
foreach ($ordering as $type => $attachment_ids) { $nonce = wp_create_nonce('comicpress');
echo '<h3>' . $this->comic_image_types[$type] . '</h3>'; $zoom_level = 40;
$index = 1; $current_user = wp_get_current_user();
foreach ($attachment_ids as $attachment_id) { if (!empty($current_user)) {
echo '<img src="' . wp_get_attachment_url($attachment_id) . '" width="60" height="60" />'; $comicpress_meta = get_usermeta($current_user->ID, 'comicpress-settings');
echo '<input size="3" type="text" name="cp[ordering][' . $type . '][' . $attachment_id . ']" value="' . $index . '" />'; if (is_array($comicpress_meta)) {
++$index; if (isset($comicpress_meta['zoom_level'])) {
$zoom_level = floor($comicpress_meta['zoom_level']);
} }
} }
} }
include(dirname(__FILE__) . '/partials/_comic-image-ordering.inc');
}
} }
} }
@ -527,6 +543,21 @@ class ComicPressAddonCore extends ComicPressAddon {
} }
} }
function handle_update_zoom_slider($info) {
$this->is_ajax = true;
$current_user = wp_get_current_user();
if (!empty($current_user)) {
$comicpress_meta = get_usermeta($current_user->ID, 'comicpress-settings');
if (!is_array($comicpress_meta)) { $comicpress_meta = array(); }
$comicpress_meta['zoom_level'] = $info['zoom_level'];
update_usermeta($current_user->ID, 'comicpress-settings', $comicpress_meta);
exit(0);
}
header('HTTP/1.1 500 Internal Server Error');
exit(0);
}
/** /**
* Handle an update. * Handle an update.
*/ */
@ -534,6 +565,11 @@ class ComicPressAddonCore extends ComicPressAddon {
if (isset($_POST['attachments'])) { if (isset($_POST['attachments'])) {
//coming from media editor //coming from media editor
$this->handle_update_attachments(); $this->handle_update_attachments();
} else if (isset($info['action'])) {
$method = 'handle_update_' . strtolower(str_replace('-', '_', $info['action']));
if (method_exists($this, $method)) {
$this->{$method}($info);
}
} else if (is_array($info['ordering'])) { } else if (is_array($info['ordering'])) {
// comic ordering // comic ordering

View File

@ -0,0 +1,43 @@
<input type="hidden" name="cp[_nonce]" value="<?php echo $nonce ?>" />
<div id="ordering-zoom-slider-holder">
<div id="ordering-zoom-slider">
<div id="ordering-zoom-handle"></div>
</div>
</div>
<div id="comic-ordering-holder">
<?php foreach ($ordering as $type => $attachment_ids) { ?>
<h3><?php echo $this->comic_image_types[$type] ?></h3>
<div id="comic-ordering-<?php echo $type ?>">
<?php foreach ($attachment_ids as $attachment_id) { ?>
<div class="cp-comic-attachment" id="attachment_<?php echo $attachment_id ?>">
<img src="<?php echo wp_get_attachment_url($attachment_id) ?>" border="0" height="<?php echo $zoom_level ?>" />
</div>
<?php } ?>
</div>
<?php } ?>
</div>
<script type="text/javascript">
(function() {
new Control.Slider('ordering-zoom-handle', 'ordering-zoom-slider', {
axis: 'vertical',
range: $R(40, 150),
sliderValue: <?php echo $zoom_level ?>,
onChange: function(v) {
new Ajax.Request(ComicPressAdmin.ajax_uri, {
method: 'post',
parameters: {
'cp[_nonce]': ComicPressAdmin.nonce,
'cp[action]': 'zoom-slider',
'cp[zoom_level]': v
}
});
},
onSlide: function(v) {
v = Math.floor(v);
$$('#comic-ordering-holder img').each(function(i) { i.setAttribute('height', v); });
}
});
}());
</script>

View File

@ -2,16 +2,30 @@
padding-left: 20px padding-left: 20px
} }
.ui-draggable {
border: solid black 1px;
background-color: #ddd
}
.cp-category-info span { .cp-category-info span {
cursor: move; cursor: move;
color: #004 color: #004
} }
.placeholder { #ordering-zoom-slider-holder {
border: dashed #ddd 2px width: 30px;
}
#ordering-zoom-slider {
height: 150px;
width: 6px;
border: solid #ccc 1px;
background-color: #ddd;
position: relative;
margin-left: 12px
}
#ordering-zoom-handle {
height: 4px;
width: 16px;
border: solid #999 1px;
background-color: #aaa;
position: absolute;
cursor: move;
margin-left: -6px
} }

0
js/ComicImageOrdering.js Normal file
View File