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 2011-02-20 | YEMblog
    • cayman #
    • end set #
    • push on is always a good thermometer for the tightness of tab. were at 99.8 degrees #
    • dancin furiously. getting my ya yas out before long drive home #
    • push on til the day #trey #
    • typically slow and funky version of the way i feel #trey #
    • ride home up and at em like nothing happened #thankgod #
    • the young girl goes on her dads shoulders and holds sign for trey to see . t$ acknowledges and waves at girl. #tenderasfuckmoment #
    • drifting #trey #
    • intense finish. more patient than many recent ph versions #
    • after toying with lots of textural jams trey now tears into more of some typical sand shredding #
    • my ride home after the show is sleeping in the chair next to me #notagoodsign #
    • sand #trey #
    • "tom's request" birdwatcher #trey #
    • trey tells tony that batman looks like a bug before horn meltdown #wtf #
    • i didnt see chainsaw's boots straight outta dallas #
    • windora bug #phish #
    • no jam #wtf #
    • this one's hitting home tonight #
    • such an albany song :) #mycoverwarspick #
    • ooh child! #trey #
    • trey "that sounded good chainsaw do it again" #
    • chainsaw solo #
    • sweet and dandy #trey #
    • ray hops on clav trey hits afterburners #
    • trey cutting santana-esque rhythms to build to peak #
    • horns leave ray leads jam #
    • night speaks #trey #
    • trey is giddy as jha throws down verses with venom. venomous as fuck even #
    • what a great cover choice. #
    • trey sings damon's vocals jha does rap #
    • clint eastwood #trey #
    • kuroda doing masterful purple and red sweeps of venue #
    • jam more of a deep groove with this ensemble #
    • brash horn line sounds fabu #
    • thanks for the spoiler on hidden track, trey :) #
    • ocelot #trey #
    • done done it! #
    • kuroda's lights are great but his sage smells terrible #
    • horns back to close 'er out0 #
    • band hits on nice descending pattern. a poor man's mind left body jam #
    • cow farmer milks clav adding countermelodies to trey dirty riffing #
    • horns leave stage as trey ray russ and tony get down to biz #
    • really thought wed see jah volunteer t-shirt @daveoatht #
    • shredsio to start. someone came to play #
    • money lobe and change #trey #
    • lights #
    • end set #thatwasablast #
    • devil went down to georgia #
    • trey tells that this a story by a rabbi who went down to the crossroads. a bit of klezmer blues #trey #
    • first #trey solo #
    • russ plays cool shuffle beat using brushes #
    • valentine #trey #
    • now all of tab is out #
    • havent heard this song in years. #voltz #
    • black #trey #
    • brings out ray #trey #
    • trey put tons of thought and practice into prepping the acoustic material. nice to see #
    • velvet sea #
    • treys pissed at tom for not telling him he was coming #
    • tom gets treys attention #trey #
    • capo on fret 2. trey talks about his songwriting sessions with tom #trey #
    • brings out "jha" and "chainsaw" #
    • itd be funny if he jammed this one out #
    • halleys #
    • joy #trey #
    • trey alternating between banging percussive sounds on guitar and playing the chords #
    • buffalo bill! #
    • trey does guelah dance after song #
    • trey finger picking dark arpeggios #
    • guelah papyrus #coolarrangement #trey #
    • stealing time #
    • "that song contains my favorite tom line of all-time tossed with the salad and bailed with the hay" #
    • sound reverberating nicely round palace #
    • limb by limb #trey #
    • #i wrote this song nearby in saratoga" bdtnl #
    • "so nice to be back in albany i have a lot friends here" caspian #trey #
    • capo still on 3rd fret #
    • the wedge #
    • 3rd fret capo'd. trey playing percussion on guitar at times #
    • free #trey #
    • title track of all things must pass over pa #trey #
    • five year old girl holding a "trey, this is my first concert. please play drifting" sign #
    • venue not even half full yet. all things must pass preshow music #trey #
    • making strides up the thruway. bringing back memories of my last trey albany show on 5/15/99. bell bottom blues was amazing #
    • Thanks to YouTube user Nevaklass for uploading his vids from last night's show! Great work http://www.youtube.com/user/nevaklass #trey #
    • Follow @originalwyllys @phanart and us (@YEMblog) for tweets from tonight's Trey Anastasio show in Albany #phish #
    • Trey Anastasio and TAB shook it like a polaroid picture last night in Portland. Setlist, Recap and Videos = http://bit.ly/gGtzqd #phish #

    Post a Comment

    You must be logged in to post a comment.