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-10 | YEMblog
    • Check out friend of YEMblog Jen Bernstein's review, videos & photos from Phish @ the Greek, Night One http://bit.ly/greekn1 [via @nycjamgal] #
    • Be sure to follow @tweeprise as he (she)'s been taking and tweeting incredible photos from #phish I've used them in all my HT recap posts #
    • As a reminder, here's our list of over 20 folks tweeting from Telluride http://twitter.com/YEMblog/tweeting-from-telluride #phish #
    • Are you heading to Alpine and/or Deer Creek and tweeting about your experience? Let us know and we'll add u to those twitter lists #phish #
    • Today on YEMblog: Telluride reviews, stories, audio & video, Greek reviews + more http://yemblog.com #phish #
    • @taopauly Have a great 200th show!!! #phish #
    • Want an easy way to support Mockingbird Foundation and assure Live Phish continues? Buy a soundboard this tour. http://j.mp/bfZXv6 #phish #
    • Poster – Telluride (by Tyler Stout): http://bit.ly/9FHVKQ #phish #
    • What a set. Piper and boogie on take the cake.one more day!! #
    • You aint seen nothing like the might Quinn! #
    • Not that I ever forgot, but this is why I love this band . Post show music: aint no mountain high enough #
    • Phish @ Telluride: Complete Setlist and Recap – http://bit.ly/96SREl #phish #
    • Show #
    • Tweeprise #
    • E: Quinn the Eskimo #
    • Quinn! #
    • Telluride #1 Set 2: Sand -> BDTNL, Prince Caspian -> Tweezer -> Boogie On -> Piper, Mist, Bowie, ADITL E:… http://bit.ly/96SREl #phish #
    • Set 2 1:20 #
    • Set, 1046 #
    • Having read the boook #
    • Aditlife #
    • Phish @ Telluride #1 Set 2: Sand -> BDTNL, Prince Caspian -> Tweezer -> Boogie On -> Piper, Mist, Bowie http://bit.ly/96SREl #phish #
    • Bowie #
    • Mike slowing it down. Dream-like. #
    • Something especially dead-like in this song. Band harnessing it perfectly right now #
    • Intimate as fuck #
    • >mountains in the mist #
    • Really explorative. Heavy space FX #
    • Piper #
    • Page droping some high pitched chords into the fray > #
    • Phish @ Telluride #1 Set 2: Sand -> BDTNL, Prince Caspian -> Tweezer -> Boogie On -> Piper http://bit.ly/96SREl #phish #
    • Mike leading the way on some nasty type 2 #
    • Fight bell. Like 10 times in a row #
    • >boogie on #
    • Thick and tarry #
    • Mike leading groove. Very funky. #
    • TWEEZER #
    • Phish @ Telluride #1 Set 2: Sand -> BDTNL, Prince Caspian -> Tweezer http://bit.ly/96SREl #phish #
    • Outer space type 2 #
    • Caspian #
    • Type 1 all the way> #
    • >bdt#l #
    • Abrupt change. Lots of space and clav #
    • Phish @ Telluride #1 Set 2: Sand -> BDTNL http://bit.ly/96SREl #
    • Trey leading all the way. Really disciplined and masterful use of the whammy #
    • A little Siren loop and lots of mike #
    • Kuroda nailing it. Stars are out too. #
    • 927 start. #
    • Sand. #
    • Lights #
    • Ck kept deep purple show lights on during break #
    • Highlights: wedge tapped into something big, Julius had so much energy #
    • Break Music:telluride sessions by strength in numbers #
    • Setbreak @ 850. Set was 1:17. #
    • Set #
    • Raging #
    • Julius #
    • Telluride #1 Set 1: Disease, Camel Walk, Ocelot, Light Up or…, Summer '89, Stash, Cavern, Wedge, Possum http://bit.ly/96SREl #phish #
    • Possum #
    • Wedgy as fuck. Ser tho, this is touching on something huge and joyful #
    • Midset Caven! Evryones going nuts #
    • Wedge #
    • Telluride #1 Set 1: Down W/ Disease, Camel Walk, Ocelot, Light Up or Leave Me Alone, Summer of 89, Stash, Cavern http://bit.ly/96SREl #phish #
    • Caven #
    • Stash #
    • Telluride #1 Set 1: Down With Disease, Camel Walk, Ocelot, Light Up or Leave Me Alone, Summer of '89 http://bit.ly/96SREl #phish #
    • Summer of '89 #
    • Trey: "still beautiful here" #
    • Light up or leave me alone #
    • Sun beginning to set, shadows dancing on the mountains. Nice and slow version. #
    • Telluride #1 Set 1: Down With Disease, Camel Walk, Ocelot http://bit.ly/96SREl #phish #
    • Ocelot #
    • Slow, thick and funky #
    • Camelwalk #
    • Back into machine gun #
    • Phish @ Telluride #1 Set 1 – Down With Disease http://bit.ly/96SREl #phish #
    • DOWN W DISEASE #
    • Lights 733pm #
    • Light rig seems scaled down. The 3-screen setup is missing. Preshow music@706- cripple creek by the band #
    • Preshow music @ 759 – the night they drove old dixie dn by the band #
    • Phans, musicians and venders all together in a compact field space among these gorgeous mountains. #
    • Setup: just a small wooden shed looking out on a long green field. Beautiful in its simplicity. #
    • Just Waiting now. All with thef world is right. #
    • Most know, but for those who dont:tonight is the 15th anniversary of jerry's death. Will we see a Dead tune or tease tonight? #
    • You can hear it all walking down Colorado avenue. #
    • Soundcheck: Funky bitch, ginseng Sullivan, cities, 46 days #
    • The owner, bertrand, will be attending his phirst show tonight!!! His wife went to college at uvt with the boys! #
    • Just had a spectacular chocolate crepe from place des crepes on Colorado ave, next to the Sheridan. Highly recomended!… #
    • Here's a List of 18 Fans Tweeting From The Telluride Shows: http://twitter.com/YEMblog/tweeting-from-telluride #phish #
    • Little bit of rain every hour or so, but otherwise about 65 and partly cloudy. Beautiful day for a phish show. #
    • Just had the best sandwich of my life at merle's brown bag. Killer sour dough AND they'll put ruffles in the sandwich for ya #
    • What an amazing town. A quick shout out to the affordable inn of montrose. Your conti brekky was second to none. #
    • Complete Video Footage of the Light from Greek3 w/ Sync'd SBD Audio – http://j.mp/dzWjCn #phish #
    • A couple of links o' the day: @dogoneblog on the Greek – http://fb.me/GeMnhoBL Lefsetz on Telluride – http://j.mp/d40mMP #phish #

    Post a Comment

    You must be logged in to post a comment.