Michael Heilemann.
If you have Dunstan's Time Since installed, this plugin uses it for the title="" attributes on the comments and posts. (For WordPress 1.5) Author: Brian Meidell Author URI: http://meidell.dk/ Version 1.5: Now works without LOCK TABLE and CREATE TEMPORARY TABLE priviledges. Version 1.5.1: Can't remember what I did here Version 1.5.2: Fixed count select statement to not include spammy comments Version 1.5.3: Properly excludes track- and pingbacks Version 1.5.4: Excludes posts that are not published, even if they have comments Version 1.5.5: Fade old comments, fixed bug that wreaked havoc with Time Since Version 1.5.6: Bugfix from Jonas Rabbe (http://www.jonas.rabbe.com/) pertaining to timesince Version 1.5.7: Bugfix so old colors can be darker than new colors (stupid oversight), thanks to http://spiri.dk for spotting it. Bugfix where single digit hex would cause invalid colors, thanks to http://www.wereldkeuken.be/ for the fix. Version 1.5.8: Updated to work with WordPress 2.1 alpha by M. Heilemann. */ function blc_latest_comments($num_posts = 5, $num_comments = 6, $hide_pingbacks_and_trackbacks = true, $prefix = "
  • ", $postfix = "
  • ", $fade_old = true, $range_in_days = 10, $new_col = "#444444", $old_col = "#cccccc") { global $wpdb; function clamp($min, $max, $val) { return max($min,min($max,$val)); } $usetimesince = function_exists('time_since'); // Work nicely with Dunstan's Time Since plugin (adapted by Michael Heilemann) // This is compensating for the lack of subqueries in mysql 3.x // The approach used in previous versions needed the user to // have database lock and create tmp table priviledges. // This uses more queries and manual DISTINCT code, but it works with just select privs. if(!$hide_pingbacks_and_trackbacks) $ping = ""; else $ping = "AND comment_type<>'pingback' AND comment_type<>'trackback'"; $posts = $wpdb->get_results("SELECT comment_post_ID, post_title FROM ($wpdb->comments LEFT JOIN $wpdb->posts ON (comment_post_ID = ID)) WHERE comment_approved = '1' AND $wpdb->posts.post_status='publish' $ping ORDER BY comment_date DESC;"); $seen = array(); $num = 0; if($fade_old) { $max_time = $range_in_days * 24 * 60 * 60 ; $r_new = hexdec(substr($new_col, 1, 2)); $r_old = hexdec(substr($old_col, 1, 2)); //$r_min = min($min, $max); //$r_max = max($min, $max); $r_range = ($r_old-$r_new); $g_new = hexdec(substr($new_col, 3, 2)); $g_old = hexdec(substr($old_col, 3, 2)); //$g_min = min($min, $max); //$g_max = max($min, $max); $g_range = ($g_old-$g_new); $b_new = hexdec(substr($new_col, 5, 2)); $b_old = hexdec(substr($old_col, 5, 2)); //$b_min = min($min, $max); //$b_max = max($min, $max); $b_range = ($b_old-$b_new); } // print "ranges: $r_range, $g_range, $b_range
    "; // print "r: ".(0.5*$r_range+$r_new)."
    "; foreach($posts as $post) { // The following 5 lines is a manual DISTINCT and LIMIT, // since mysql 3.x doesn't allow you to control which way a DISTINCT // select merges multiple entries. if(array_key_exists($post->comment_post_ID, $seen)) continue; $seen[$post->comment_post_ID] = true; if($num++ > $num_posts) break; $commenters = $wpdb->get_results("SELECT *, UNIX_TIMESTAMP(comment_date) AS unixdate FROM $wpdb->comments WHERE comment_approved = '1' AND comment_post_ID = '".$post->comment_post_ID."' $ping ORDER BY comment_date DESC LIMIT $num_comments;"); $count = $wpdb->get_var("SELECT COUNT(comment_ID) AS c FROM $wpdb->comments WHERE comment_post_ID = $post->comment_post_ID AND comment_approved = '1' ".$ping); $i = 0; $link = get_permalink($post->comment_post_ID); if($usetimesince) $title = " title=\"Last comment was ".time_since($comment->unixdate)." ago\""; else $title = ""; echo $prefix."".stripslashes($post->post_title). "  ".$count."
    \n"; foreach($commenters as $commenter) { if($usetimesince) $title = " title=\"Posted ".time_since($commenter->unixdate)." ago\""; if($fade_old) { $diff = time() - $commenter->unixdate; $r = round($diff/$max_time*($r_range))+$r_new; $r = clamp(min($r_new, $r_old), max($r_new, $r_old), $r); $g = round($diff/$max_time*($g_range))+$g_new; $g = clamp(min($g_new, $g_old), max($g_new, $g_old), $g); $b = round($diff/$max_time*($b_range))+$b_new; $b = clamp(min($b_new, $b_old), max($b_new, $b_old), $b); $r_hex = str_pad(dechex($r), 2, '0', STR_PAD_LEFT); $g_hex = str_pad(dechex($g), 2, '0', STR_PAD_LEFT); $b_hex = str_pad(dechex($r), 2, '0', STR_PAD_LEFT); $colstr = " style=\"color: #".$r_hex.$g_hex.$b_hex.";\""; } if($i++ > 0) echo ", "; echo "comment_ID."\"$title>".stripslashes($commenter->comment_author).""; } if($count > $num_comments) echo " [...]"; echo "".$postfix."\n"; } } ?> @YEMblog Twitter Updates for 2010-08-08 | YEMblog
    • Complete Greek Coverage @ HT: Night 1 – http://bit.ly/9p3pxQ Night 2 – http://bit.ly/9z6Z9i Night 3 – http://bit.ly/cNa2ue #phish #
    • Phish @ the Greek, Night Three, August 7 – Setlist and Complete Recap http://bit.ly/cNa2ue #phish #
    • Great Work by David "ZZYZX" Steinberg on Tweets Tonight. Quite a Twitter Debut. Hopefully He'll Do It Again!!! And Happy 100th DaveO #phish #
    • Late in the evening for post show music. #
    • Hope everyone enjoyed the glimpse into my usual notes. #
    • End enc 18:26 #
    • Trey jumping around like a madman #
    • Phish @ the Greek #3 Set Two: Wilson > Light > 20 Years > Hood > Theme, 2001 > Suzy > Slave E: Lizards, 1st Tube http://bit.ly/cNa2ue #phish #
    • 10:01 end. 10:14 first cous. Errr tube #
    • A bit rough in if I had a dog. #
    • Last lizards enc 11/22/94 I believe. #
    • Enc: lizards #
    • Phish @ the Greek #3 Set Two: Wilson > Light > 20 Years Later > Harry Hood > Theme, 2001 > Suzy > Slave http://bit.ly/cNa2ue #phish #
    • 83:38. End of a stunning set #
    • Not quite as stunning as Portsmouth perhaps but still… #
    • Punch them in the face for lying! #
    • If anyone tries to tell you night 3 wasn't the best… #
    • 72:02 > slave!! #
    • Uber high energy! #
    • Rockin!!!! #
    • 67:24 extra Susie jam! #
    • What's up with that table next to mike? #
    • Page took a monster solo in the second jam #
    • 61:23 > Susie #
    • Phish @ the Greek #3 Set Two: Wilson > Light > 20 Years Later > Harry Hood > Theme, 2001 > Suzy http://bit.ly/cNa2ue #phish #
    • Deep mike between verses. #
    • First verse @ 56:31. More patient. #
    • We have fight bell! #
    • 52:45 end song. 52:55 2001 #
    • Nice nice peak in the theme. #
    • 43:50 > theme #
    • Phish @ the Greek #3 Set Two: Wilson > Light > 20 Years Later > Harry Hood > Theme http://bit.ly/cNa2ue #phish #
    • Trey just sustained a note to create quiet beauty. Taken way down. #
    • 37:40 a little atypical hood jamming. Good stuff! #
    • The beauty of the light jam is continuing. Great interplay. #
    • West coasters like to hoard and throw at peaks. #
    • And here come the glowsticks all old school style. #
    • Trey is dancing around a bit in the intro #
    • 28:49>hood #
    • 27:13 jam is going out a bit #
    • Phish @ the Greek #3 Set Two: Wilson -> Light > 20 Years Later http://bit.ly/cNa2ue #phish #
    • 21:24 > 20 years later #
    • 18:55 things speed up #
    • This jam is just beautiful. More like this please! #
    • 14:20. Trey defines a theme. #
    • 12:46 pretty mellow mike led jam. #
    • Phish @ the Greek #3 Set 2: Wilson > Light http://bit.ly/cNa2ue #phish #
    • 11:19 jam growing more dissonant #
    • Jam @ 7:12 #
    • Great jam in this one year ago tonight. #
    • 4:12 > light #
    • I suspect AT&T will work better in telluride than anywhere in east bay… #
    • Wilson #
    • Lights. Right at 30 m #
    • Plan your trips accordingly! #
    • 3.0 breaks are closer to 30 m than 2.0's 45 m #
    • Ed. Note: Want to Wish Last Night's Tweeter, DaveO, A Happy 100th Show. Thanks for all the help w/ YEMblog and Hidden Track – Scotty #
    • Felt like best first set of the run #
    • 72:05 end set #
    • Mike was doing cool fills in intro #
    • 64:50>C0 #
    • Greek, #3 – Set 1: AC/DC Bag > Foam, Jibboo, Reba, Sleep Again, Army of 1, Poor Heart > 46 Days, Tube, Zero http://bit.ly/cNa2ue #phish #
    • Fastest I've ever heard #
    • FAST funk jam #
    • 60:37 > tube #
    • Getting dark, spacey. #
    • 59:10 more of a blues funk thing #
    • "46 daaaaaaaaaays!" screamed. Rocking outro #
    • Do the hula-hula dance riff by Trey #
    • 55:16 all the girls in France #
    • Phish @ the Greek, #3 – Set 1: AC/DC Bag > Foam, Jibboo, Reba, Sleep Again, Army of One, Poor Heart > 46 Days http://bit.ly/cNa2ue #phish #
    • 52:47> 46 days #
    • We need a mike song next to get them all in row #
    • 50:36 end 50;48 poor <3 #
    • Trey is the optimist here. Page just gives up #
    • Would be nice to have sun to soak in. Grey grey skies #
    • It's the solo band ballad section of the show. #
    • Phish @ the Greek, Night 3 – Set 1: AC/DC Bag > Foam, Gotta Jibboo, Reba, Sleep Again, Army of One http://bit.ly/cNa2ue #phish #
    • 45:22 end. 45:52 army of one #
    • Page is bringing this home. #
    • 39:27 end. 39:48 sleep again #
    • Someone timed a large confetti throw to the start of the jam section #
    • Interesting wood block work by fishman in the ingredient verse #
    • Phish @ the Greek, Night 3 – Set 1: AC/DC Bag > Foam, Gotta Jibboo, Reba http://bit.ly/cNa2ue #phish #daveos100th #
    • 27:29 Reba #
    • VERY nice peak. 25:55 end #
    • 22:30. The jam is starting to pick up. Lots of page/mike #
    • 15:35 jibboo #
    • 15:26. End foam #
    • Phish @ the Greek, Night 3 – Set 1: AC/DC Bag, Foam http://bit.ly/cNa2ue #phish #
    • Little rough in the intro #
    • Straightforward rocking version. Nice peak! #
    • 6:25 > foam #
    • Mike looks cold. Jeans and polar fleece #
    • AT&T is the suxor #
    • Ac dc bag #
    • Lights #
    • Second best: spread it round #
    • Best sign so far: stage banter reprise #
    • Any changes in direction immediately post-tweet #
    • Apologies in advance for a #
    • Instead of using my infamous clipboard, I'll tweet #
    • So here's the plan for tonight: #
    • Loud chants of "let's go Jesus" in response. #
    • Got some Jesus people here harassing the front of the line. #
    • Double Phishead Brew, limited release from Silverton Brewery for #phish http://tweetphoto.com/37497737 [via @TellurideHotels] #
    • Let us know if you're tweeting from Telluride and we'll add you to that list #phish #
    • Here's a list of those tweeting from the show tonight: http://twitter.com/YEMblog/tweeting-from-the-greek #phish #

    Post a Comment

    You must be logged in to post a comment.