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-12-31 | YEMblog
    • Thanks for everything guys it's been a pleasure @joshkorin signing out happy new year! #
    • Finally a huge shout out to my best friend & love of my life @interactiveAmy #
    • Can't thank Scotty enough this was a pleasure I leave you to the man himself #
    • Great first night extremely well played show I had a blast #phishNYE #
    • End show #phishNYE #
    • Here we go Tweeprise #phishNYE #
    • Security in our section playing chase the spinning spunion… #phishNYE #
    • E: antelope #phishNYE #
    • MSG1 Set II tweezer -> light -> theme -> mfmf > axilla, fluffhead, boogie on > 2001 > Suzy #phishNYE #
    • End set #phishNYE #
    • Trey & Page hook up in a real nice interplay… #phishNYE #
    • Suzy for the one & only @soozygreenberg… #phishNYE #
    • One of the better 2001's in recent memory…. #phishNYE #
    • Huge Cactus bass intro to Boogie On (remember last 12/30's Boogie On?) #phishNYE #
    • Mike slappin the Modulus extra funky right into 2001 #sosmooth #phishNYE #
    • Trey/Mike syncopated hop in full effect #PhishNYE #
    • Garden goes wild for Fluff came to New York lyric switch… #phishNYE #
    • Buttery smooth > Fluffhead #phishNYE #
    • MSG1 Set 2:Tweezer,->Light ->Theme ->My Friend ->Axilla [http://bit.ly/fwNjnZ] #phish #
    • Still no gamehendge… #justsayin #phishNYE #
    • My Friend x 2 #phishNYE #
    • MSG1 Set II Tweezer > Light > Theme From The Bottom #phishNYE #
    • Really smooth >Theme excellent Light #phishNYE #
    • Fish really driving the tweezer jam… #phishNYE #
    • MSG1 Set 2:Tweezer,->Light [http://bit.ly/fwNjnZ] #phish #
    • > Light #phishNYE #
    • CK 5 roygbiving behind the stage phanners loving it… #phishNYE #
    • Page hops on the clav as we head into UFO territory #phishNYE #
    • Just the slightest whole lotta love tease…. #phishNYE #
    • CK5 stellar as he ever was #
    • Set II we are off & running w/ tweezer #phishNYE #
    • Lights… #
    • First set highlights: cities, quinn, fat man, timber very well played set 1 #phishNYE #
    • Trey extremely sharp though very solid zero solo #phishNYE #
    • End set #phishNYE #
    • MSG1Set1:Cities,Chalkdust,Gumbo,Quinn,Halleys>CamelWalk,Maze,Driver, Bathtub,FatManinBathtub,Timber,Golgi,Zero [http://bit.ly/fwNjnZ] #phish #
    • Golgi #phishNYE #
    • MSG1 Set 1: cities, chalkdust, gumbo, quinn, halley's > camel, maze, gin, fat man, timber, golgi, zero #phishNYE #
    • Timber has always been a personal fave always pleased to get it #phishNYE #
    • MSG1 Set1: Cities, Chalkdust,Gumbo,Quinn,Halleys>Camel Walk,Maze,Driver, Bathtub,Fat Man in the Bathtub,Timber [http://bit.ly/fwNjnZ] #phish #
    • Little conference now Timber #phishNYE #
    • And we have our first Little Feat Halloween set to reappear with Fat Man #phishNYE #
    • Good sized La Grange sign spotted by rear of floor #phishNYE #
    • Fairly straight fwd thru Gin jam nice mike/trey interplay #phishNYE #
    • Little slower tempo… #phishNYE #
    • @ahand yes that's the setlist thus far… Now Gin #phishNYE #
    • MSG1 Set1: Cities, Chalkdust, Gumbo, Quinn, Halleys -> Camel Walk, Maze, Driver, Bathtub [http://bit.ly/fwNjnZ] #phish #
    • 200 & 300 levels erupt in glowies cc: @GlowStickWars #makeitrain #phishNYE #
    • Trey appears dialed in this evening real sharp thus far #phishNYE #
    • Driver #phishNYE #
    • Trey charges hard into Halley's solo… #Phish #
    • Set I: cities, chalkdust, gumbo, quinn, halley's > camel walk, maze #phishNYE #
    • Maze #phishNYE #
    • Beautiful CK5 chase patterns as band digs back in #phishNYE #
    • Real abrupt > Camel Walk #phish #
    • Halley's #phish #
    • Set I: Cities, chalkdust, gumbo, quinn #Phish #
    • Quinn #phishNYE #
    • This crowd is hyped ready to go from minute one huge energy #phishNYE #
    • Gumbo #Phish #
    • Real nice thru chalkdust jam #phishNYE #
    • Lights! #phish #
    • Lights! #
    • Chalkdust #Phish and #YEMSG goes ape shit #
    • Page up on clav layin it down #
    • Steady & smooth thus far… #
    • Cities opener for @amontag #
    • Should be any minute now…huge sign down front little trouble making it out stay tuned… #phishNYE #
    • Last minute opener calls guys let's hear em… #YEMSG #phish #
    • At seats starting to fill in #YEMSG is ready to party. Section 304 has come to get down #
    • Quick sighting of @UNOlker @Roughsax & @stringcheesemom have a great show guys #
    • Quick sighting of @UNOlker @Roughsax & @stringcheesemom have a great show guys. #
    • Arrival at #YEMSG let's go #phish #
    • Found some of the #chitwibe @amontag & @AndrewJStone are ready to get down thanks for the love & support guys! #
    • @JesseMixMan haven't seen many tickets yet but still early #
    • Pre game festivities in full swing crowd by the Garden is electric nothin like an NYE run in New York. #phish #
    • Thanks Scotty it's a privilege looking fwd to a great night I'll be updating periodically & will be in full effect upon arrival #YEMSG #
    • Alrighty, I'm gonna sign off (unless any news breaks) and hand off to @joshkorin so I can enjoy my 200th! Have fun, folks – Scotty #
    • @shapsio My Rankings of 12/30 Shows From '94 to '09: 1. '97 2. '99 3. '09 4. '95 5. '03 6. '94 7. '98 8. '96 #phish #iama1230guy #
    • @YEMblog Guest Tweeter #yemsg Schedule = 12/30 @joshkorin 12/31 = Me (@heyscottyb) 1/1 = Sammy D. (@dogoneblog) #phish #
    • One of my favorite music writers, RS/SPIN/NPR's @WilliamHermes, will be tweeting from tonight's Phish show on his feed #phish #
    • Poster and LE Subway Tokens on sale outside the venue at 5PM Remaining posters & coins available at inside merch stands [via #phish fb] #
    • New Merch For #YEMSG http://on.fb.me/eZGuQo – Limited Edition Phish Subway Tokens #phish #
    • MSG Poster by Ken Taylor – http://bit.ly/h42c7V [via @posterdan] #phish #
    • Helloooo Newark! @joshkorin here made it to the east coast will talk to everybody from the Garden this evening. Enjoy you day in NY phans #
    • Also, I'd be surprised if this happens RT @MSGEconcerts @phish takes the stage @ 7:30 sharp #phish #
    • I can see Trey discussing tonight's hash tag right now ;) RT @MSGEconcerts The band asked us to use #phishNYE for all 3 nights #
    • Playlist of 12/27 Videos by MKDevo is Now Complete http://bit.ly/eAFO4q 12/28 Playlist Set Through Hood http://bit.ly/idgW9F #phish #
    • I feel like Phish fans are either of the 12/29 variety or the 12/30 variety. I'm a 12/30 guy. My favorite day of the year! Happy Holiday #
    • Great article featuring a debate on whether 12/29/97 is better than 12/29/95 at @onlinephishtour http://bit.ly/dE9qCO #phish #
    • Have you heard/seen Tuesday night's much-discussed Harry Hood? MKDevo's video is up on YouTube: http://youtu.be/Hfa3d9bpZeE #phish #
    • Reminder, @joshkorin on tweets tonight. Show #200 for me tonight, can't help but think of show #1 http://bit.ly/ikAREg – SB #phish #

    Post a Comment

    You must be logged in to post a comment.